W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
開發(fā)者開發(fā)快應(yīng)用項目時,需要利用腳手架創(chuàng)建一個快應(yīng)用的初始化項目并編寫項目源代碼;
之后使用編譯工具編譯項目得到構(gòu)建文件(以rpk后綴命名,如:?com.application.demo.rpk
?);
當?shù)玫巾椖烤幾g后的構(gòu)建文件后,可以使用調(diào)試器安裝并運行該項目。
上面就是編譯工具的主要任務(wù):
1) 初始化項目:創(chuàng)建空的快應(yīng)用項目工程;
2) 編譯項目:校驗源碼文件,構(gòu)建項目得到產(chǎn)出文件;
3) 下載與更新產(chǎn)出:建立HTTP服務(wù)器,當手機運行時請求資源和調(diào)試應(yīng)用時,完成下載更新;
其中第二步?編譯項目
?的工作量最大,開發(fā)者對項目編譯的需求也各不相同,因此提供下面的個性化配置能力。
編譯工具提供了多種編譯能力,開發(fā)者可以根據(jù)項目需求進行設(shè)置。
比如開發(fā)者想啟用端到端的測試能力,可以在編譯項目時攜帶參數(shù)?--enable-e2e
?。這樣,開發(fā)者就可以在運行快應(yīng)用時進行端到端的測試。
通常有兩種方式設(shè)置編譯參數(shù),以開發(fā)者開啟端到端測試能力并抽取單獨的 source-map 文件為例:
npx hap build --enable-e2e --devtool=source-map
或者
npm run build -- --enable-e2e --devtool=source-map
注意:如果是上面通過 npm 運行,記得攜帶:?--
?標識讓參數(shù)傳遞到內(nèi)部的命令;
quickapp.config.js
?,并配置cli屬性;module.exports = {
cli: {
enableE2e: true,
devtool: 'source-map'
}
}
npx hap build -h
常見的編譯參數(shù)如下:
--enable-e2e
?開發(fā)者如果想針對項目的功能模塊或者接口兼容性進行真機自動化測試,可以開啟 e2e 測試能力。開啟 e2e 測試能力會導(dǎo)致rpk
體積變大,適用于項目代碼的測試用例保證場景,在項目上線階段不要啟用該能力。
使用方法請查看 自動化測試文檔。
--enable-istanbul
?開發(fā)者如果想針對項目中多次調(diào)用的部分進行優(yōu)化,可以啟用代碼覆蓋率統(tǒng)計能力。啟用該能力后,開發(fā)者可以在調(diào)試工具提供的頁面中查看各個模塊的使用情況,進行針對性優(yōu)化。
使用方法請查看 代碼覆蓋率使用文檔。
--devtool <value>
?編譯工具在編譯項目時默認將 sourcemap
打到 js 文件內(nèi),通過設(shè)置 value 可以控制sourcemap
輸出形式。具體內(nèi)容可以參考webpack的 devtool 選項。默認為none
,設(shè)置為source-map
值表示單獨輸出
sourcemap 文件。
--enable-extract-css
?快應(yīng)用在1070以上版本對樣式計算進行了優(yōu)化,啟用該能力可以將頁面和組件的樣式在編譯時進行提取,加速運行時樣式計算過程。單獨啟用會增加rpk包的體積,配合--remove-ux-style
參數(shù)可以保證 rpk 體積不變。
--enable-diagnosis
?開發(fā)中經(jīng)常需要調(diào)試頁面,之前可以使用調(diào)試器工具啟動 devtools 頁面來完成界面與 JS 的調(diào)試,有時開發(fā)者也希望能夠有一種輕量級的調(diào)試方式;
通過啟用該參數(shù),編譯時工具將會在項目構(gòu)建時,引入額外的JS文件,該文件會監(jiān)聽?console
?對象上的?error()/warn()/info()/debug()/log()
?方法調(diào)用,并將相應(yīng)的日志信息記錄下來,通過fetch請求發(fā)送到項目的服務(wù)器(通過?npm
?? run server
?)中;
服務(wù)器收到請求的信息時,會將對應(yīng)設(shè)備的日志輸出記錄在項目根目錄的?logs
?文件夾中,文件夾中的每個文件代表了一個對應(yīng)的快應(yīng)用設(shè)備運行時的日志輸出;
通過這種方式,開發(fā)者可以查看應(yīng)用運行時最新的日志輸出,方便查看內(nèi)容與定位;
內(nèi)置日志監(jiān)聽的JS實現(xiàn),請參考編譯時工具中的文件路徑,如:?./node_modules/@hap-toolkit/packager/router/lib/diagnosis.js
?;
提示:該功能從編譯時工具?hap-toolkit@0.7.0
?開始支持;
快應(yīng)用可以支持常見的前端編譯工具,目前主要針對webpack(>=4)進行兼容與設(shè)置,開發(fā)者可以在?quickapp.config.js
?文件中配置,具體配置方法如下。
在項目根目錄下增加?quickapp.config.js
?文件,項目配置文件如下:
const path = require('path')
const webpack = require('webpack')
module.exports = {
// hap命令構(gòu)建時的配置參數(shù)
cli: {
enableE2e: true
},
// 采用webpack編譯時的配置
webpack: {
resolve: {
extensions: ['.uxtest'],
alias: {
'&': path.resolve(__dirname, 'src')
}
},
module: {
rules: [
{
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
use: [
{
loader: 'url-loader',
options: {
limit: 10000
}
}
]
}
]
},
plugins: [
// webpack插件示例
new WebpackPluginDemo(),
// 自動替換代碼中的變量
new webpack.DefinePlugin({
ENV_TYPE: process.env.type
})
]
}
}
class WebpackPluginDemo {
apply(compiler) {
compiler.hooks.emit.tapAsync('WebpackPluginDemo', function (compilation, callback) {
callback()
})
}
}
開發(fā)者對項目編譯會有不同的需求,可以在?webpack
?命名空間下設(shè)置?resolve
?、?module
?、?plugins
?屬性進行自定義配置,webpack配置文檔地址。
快應(yīng)用在 Github的官方站點項目:quickappcn/hap-toolkit-usage,提供了常見的配置示例。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: