gradle读取配置文件

2018-10-30 10:58:41

最近在导入一些开源项目的时候,发现配置文件的写法和自己平时写的不一样,平时是这样写的。


apply plugin: 'com.android.application'


android {

    compileSdkVersion 23

    buildToolsVersion "23.0.2"


    defaultConfig {

        applicationId "com.example.hecun.myapplication"

        minSdkVersion 15

        targetSdkVersion 23

        versionCode 1

        versionName "1.0"

    }

   ........

}


dependencies {

    compile fileTree(dir: 'libs', include: ['*.jar'])

    testCompile 'junit:junit:4.12'

    compile 'com.android.support:appcompat-v7:23.2.1'

    compile 'com.android.support:design:23.2.1'

    compile 'com.nineoldandroids:library:2.4.0'

}


其实还有另外一种写法,有些项目中会这样写。


android {


    compileSdkVersion rootProject.ext.android.compileSdkVersion

    buildToolsVersion rootProject.ext.android.buildToolsVersion


    defaultConfig {

        applicationId rootProject.ext.android.applicationId

        minSdkVersion rootProject.ext.android.minSdkVersion

        targetSdkVersion rootProject.ext.android.targetSdkVersion

        versionCode rootProject.ext.android.versionCode

        versionName rootProject.ext.android.versionName

    }


........

}

dependencies {

    compile fileTree(dir: 'libs', include: ['*.jar'])

    compile project(":libraries:headsupcompat")

    compile project(":libraries:smooth-app-bar-layout")

    compile rootProject.ext.dependencies["design"]

    compile rootProject.ext.dependencies["appcompat-v7"]

    compile rootProject.ext.dependencies["recyclerview-v7"]

    compile rootProject.ext.dependencies["picasso"]

    compile rootProject.ext.dependencies["numberprogressbar"]

    compile rootProject.ext.dependencies["photoview"]

    compile rootProject.ext.dependencies["umeng-analytics"]

    compile rootProject.ext.dependencies["retrofit"]

    compile rootProject.ext.dependencies["rxandroid"]

    compile rootProject.ext.dependencies["okhttp-urlconnection"]

    compile rootProject.ext.dependencies["okhttp"]

    compile rootProject.ext.dependencies["butterknife"]

    compile rootProject.ext.dependencies["otto"]

    compile rootProject.ext.dependencies["glide"]

}



可以看到和我们写的不一样,应该是引用了某个地方的东西,我们去看看 



我们打开这个文件



ext {


    android = [compileSdkVersion: 22,

               buildToolsVersion: "22.0.1",

               applicationId    : "me.drakeet.meizhi",

               minSdkVersion    : 14,

               targetSdkVersion : 22,

               versionCode      : 359,

               versionName      : "2.5.9"]


    dependencies = ["appcompat-v7"        : "com.android.support:appcompat-v7:22.2.1",

                    "design"              : "com.android.support:design:22.2.1",

                    "recyclerview-v7"     : "com.android.support:recyclerview-v7:22.2.1",

                    "nineoldandroids"     : "com.nineoldandroids:library:2.4.0",

                    "picasso"             : "com.squareup.picasso:picasso:2.5.2",

                    "photoview"           : "com.github.chrisbanes.photoview:library:1.2.3",

                    "numberprogressbar"   : "com.daimajia.numberprogressbar:library:1.2@aar",

                    "umeng-analytics"     : "com.umeng.analytics:analytics:latest.integration",

                    "retrofit"            : "com.squareup.retrofit:retrofit:1.9.0",

                    "rxandroid"           : "io.reactivex:rxandroid:1.0.0",

                    "okhttp-urlconnection": "com.squareup.okhttp:okhttp-urlconnection:2.0.0",

                    "okhttp"              : "com.squareup.okhttp:okhttp:2.0.0",

                    "butterknife"         : "com.jakewharton:butterknife:7.0.1",

                    "otto"                : "com.squareup:otto:1.3.8",

                    "glide"               : "com.github.bumptech.glide:glide:3.6.1"]

}



注意,这时候需要在跟目录build.gradle中添加下面一句话


apply from: "config.gradle"


  • 2019-12-30 10:17:21

    router-link传递参数,query

    在vue-router中,有两大对象被挂载到了实例this; $route(只读、具备信息的对象); $router(具备功能的函数) 查询字符串: 去哪里 ? <router-link :to="{name:'detail',query:{id:1}}"> xxx </router-link>

  • 2019-12-30 16:48:41

    vue provide/inject详解和用法

    父子组件交互方式多种,props、vuex、 、 emit、localStorage还有就是这个provide/inject了。它适合层级比较深的组件,比如子,子孙,子孙后代的组件有好几个用到父组件的某个属性,就可以用到这个provide/inject,它可以避免写大量繁琐的传值代码 我这里为什么要使用它? 我一个知识库详情父组件中包含了大量的子组件,每个子组件都需要父组件的知识库ID,这时候我不想写大量props,就用到provide/inject进行传值了

  • 2020-01-03 00:36:00

    break和continue详解for循环

    1. break:直接跳出当前循环体(while、for、do while)或程序块(switch)。其中switch case执行时,一定会先进行匹配,匹配成功返回当前case的值,再根据是否有break,判断是否继续输出,或是跳出判断(可参考switch的介绍)。 2. continue:不再执行循环体中continue语句之后的代码,直接进行下一次循环。