Omi原理-環境搭建-創新互聯

環境搭建

Omi框架使用 Webpack + ES6 的方式去開發;使用karma+jasmine來作為Omi的測試工具。

成都創新互聯是一家專業提供大洼企業網站建設,專注與網站設計制作、成都網站設計H5頁面制作、小程序制作等業務。10年已為大洼眾多企業、政府機構等服務。創新互聯專業的建站公司優惠進行中。

Karma介紹

Karma是一個基于Node.js的JavaScript測試執行過程管理工具(Test Runner)。該工具可用于測試所有主流Web瀏覽器,也可集成到CI(Continuous integration)工具,也可和其他代碼編輯器一起使用。這個測試工具的一個強大特性就是,它可以監控(Watch)文件的變化,然后自行執行。但是集成到travis ci要把singleRun設置成true,讓其只執行一遍。

Jasmine介紹

Jasmine 是一款 JavaScript BDD(行為驅動開發)測試框架,它不依賴于其他任何 JavaScript 組件新航道培訓。它有干凈清晰的語法,讓您可以很簡單的寫出測試代碼。

開發依賴包

在package.json中,有如下配置:

  "devDependencies": {
    "babel-core": "^6.0.20",
    "babel-loader": "^6.0.1",
    "babel-preset-es2015": "^6.0.15",
    "node-libs-browser": "^0.5.3",
    "webpack": "^1.14.0",
    "jasmine-core": "^2.5.2",
    "karma": "^1.3.0",
    "karma-chrome-launcher": "^2.0.0",
    "karma-jasmine": "^1.1.0",
    "karma-webpack": "^1.8.1"
  }
  • ES6+相關依賴有babel-core、babel-loader和babel-preset-es2015

在webpack.config.js中配置js文件使用babel-loader編譯。

loaders: [    {
        loader: 'babel-loader',
        test: /\.js$/,
        query: {
            presets: 'es2015',
        }
    }]
  • webpack相關依賴有node-libs-browser和webpack

  • 其余都是單元測試相關依賴

    注意,這里使用了karma-webpack。因為使用Omi框架支持ES6+和ES5,使用karma-webpack是為了在單元測試里面使用ES6+的import和Class等語法。

在karma.conf.js中配置webpack:

    webpack: webpackConfig,
    webpackMiddleware:{
      noInfo:false
    },
    plugins: [        'karma-webpack',
        'karma-jasmine',
        'karma-chrome-launcher'
    ]

具體配置看test目錄下的karma.conf.js和webpack.test.config.js便可。

注意,karma.conf.js需要設置

// if true, Karma captures browsers, runs the tests and exitssingleRun: true,

不然,travis ci腳本執行的時候不會中斷導致執行超時異常。

npm 腳本

  "scripts": {
    "build": "webpack -w",
    "test": "karma start test/karma.conf.js",
    "hello": "webpack -w",
    "todo": "webpack -w"
  }

其中:

  • npm run build : 生成dist目錄的omi.js文件

  • npm run test : 執行單元測試

  • npm run hello : 編譯hello的demo

  • npm run todo : 編譯todo的demo

在webpack.config.js中,會根據 process.env.npm_lifecycle_event去設置不同的入口文件。所以同樣是執行webpack -w,執行結果可以不一樣。

來看下build的相關webpack配置:

if(ENV === 'build'){
    config = {
        entry: {
            omi: './src/index.js'
        },
        output: {
            path: 'dist/',
            library:'Omi',
            libraryTarget: 'umd',
            filename:  '[name].js'
        },

這里把libraryTarget設置成了umd,webpack會幫助我們build出umd的Omi。

如果是打包demo(npm run hello 和 npm run todo)的話,會進入下面的條件判斷:

else {
    config.entry = './example/' + ENV + '/main.js';
    config.output.path = './example/' + ENV + '/';}

會去example下對應的目錄查找main.js作為webpack入口文件。

這里可以看到,我們不僅用webpack build出Omi框架,也使用webpack build所有demo。

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

分享題目:Omi原理-環境搭建-創新互聯
網頁路徑:http://m.kartarina.com/article14/ccgede.html

成都網站建設公司_創新互聯,為您提供品牌網站制作域名注冊移動網站建設網站排名網站改版用戶體驗

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

微信小程序開發
主站蜘蛛池模板: 精品国产aⅴ无码一区二区| 精品无码AV一区二区三区不卡| 久久青青草原亚洲AV无码麻豆| 成人午夜精品无码区久久 | 日本精品无码一区二区三区久久久 | 久久午夜无码免费| 免费无码午夜福利片| 久久亚洲精品成人无码网站| 精品久久久久久无码中文字幕一区 | 无码精品A∨在线观看中文| 精品人妻中文无码AV在线| 国产午夜无码精品免费看| 丝袜无码一区二区三区| 韩国精品一区二区三区无码视频| 久久国产亚洲精品无码| 日韩精品无码一区二区三区 | 亚洲综合一区无码精品| 免费A级毛片无码A∨免费| 人妻系列无码专区久久五月天| 亚洲日韩乱码中文无码蜜桃臀网站| 亚洲日韩av无码中文| 日韩精品无码AV成人观看| 精品无码国产自产拍在线观看蜜 | 国产精品无码永久免费888| 亚洲精品无码专区| 久久午夜无码鲁丝片| 亚洲V无码一区二区三区四区观看| 亚洲av无码av制服另类专区| 亚洲色偷拍区另类无码专区| 亚洲人成人无码网www电影首页| 人妻丰满熟妇AV无码区免| 最新亚洲春色Av无码专区| 日韩经典精品无码一区| 精品无码专区亚洲| 老司机无码精品A| 夜夜精品无码一区二区三区 | 精品国产a∨无码一区二区三区| 亚洲国产精品无码专区影院| 久久精品无码一区二区三区| 中文字幕无码日韩专区| 国产精品无码午夜福利|