当前位置: 首页 > wzjs >正文

东莞找公司网站网站的关于页面

东莞找公司网站,网站的关于页面,搜索引擎营销的过程,做网站时兼容分辨率目录 1 -> 通过hook以及插件上下文实现动态配置 2 -> 在hvigorfile.ts中通过overrides关键字导出动态配置 3 -> 通过hook以及插件上下文动态配置构建配置 3.1 -> 修改每个hvigorNode中的build-profile.json5 3.2 -> 修改module.json5中的配置信息 3.3 -&g…

目录

1 -> 通过hook以及插件上下文实现动态配置

2 -> 在hvigorfile.ts中通过overrides关键字导出动态配置

3 -> 通过hook以及插件上下文动态配置构建配置

3.1 -> 修改每个hvigorNode中的build-profile.json5

3.2 -> 修改module.json5中的配置信息

3.3 -> 修改app.json5中的配置信息

3.4 -> 修改oh-package.json5中的依赖


1 -> 通过hook以及插件上下文实现动态配置

Hvigor支持stage模型在hvigor hook中操作从硬盘上读取的以下配置文件:

  • 每个hvigorNode中的build-profile.json5
  • module.json5
  • app.json5
  • 每个module下的oh-package.json5文件中的dependency、devDependency、dynamicDependency以及version。

目前可以通过hvigor对象提供的上下文直接获取和修改配置以实现动态配置构建配置、并使能到构建的过程与结果中。

在hvigorfile.ts或hvigorconfig.ts文件中,可以使用Hvigor提供的API接口来实现此能力。

相比于下面的overrides的能力来说,通过hook以及插件上下文来动态修改签名和编译配置更为灵活和易于理解,功能也更为全面,推荐使用此种方式。

2 -> 在hvigorfile.ts中通过overrides关键字导出动态配置

在hvigorfile.ts中,我们约定在导出的对象中的config.ohos属性里接收编译的配置:

export default {  system: hapTasks,  config: {  ohos: {...}    }
}

目前可以在工程级的hvigorfile.ts的config.ohos中配置的字段:

  • overrides:定义起覆盖作用的字段的位置,会在构建过程中覆盖原有的对应配置项。
    • signingConfig:签名配置,对应build-profile.json5里的signingConfig配置项。
      • type
      • material
        • certpath
        • storePassword
        • keyAlias
        • keyPassword
        • profile
        • signAlg
        • storeFile
    • appOpt:对应​​​​​​​app.json5里的配置项字段。
      • bundleName
      • bundleType
      • icon
      • label
      • vendor
      • versionCode
      • versionName

目前可以在模块级的hvigorfile.ts的config.ohos中配置的字段:

  • overrides:定义起覆盖作用的字段的位置,会在构建过程中覆盖原有的对应配置项。
    • buildOption:对应build-profile.json5里的​​​​​​​buildOption配置项。
      • arkOptions
      • externalNativeOptions
      • napiLibFilterOption
      • nativeLib
      • resOptions
      • sourceOption

配置在overrides项中的参数,其优先级会高于在配置项中的对应字段。

3 -> 通过hook以及插件上下文动态配置构建配置

3.1 -> 修改每个hvigorNode中的build-profile.json5

此处只举例为单个node注册hook并修改build-profile.json5的信息。

例如需要修改根目录下的build-profile.json5的签名信息,则在项目根目录下的hvigorfile.ts中添加如下内容:

import { appTasks, OhosAppContext, OhosPluginId } from '@ohos/hvigor-ohos-plugin';
import { hvigor,getNode } from '@ohos/hvigor'// 获取根节点
const rootNode = getNode(__filename);
// 为根节点添加一个afterNodeEvaluate hook 在hook中修改根目录下的build-profile.json5的内容并使能
rootNode.afterNodeEvaluate(node => {// 获取app插件的上下文对象const appContext = node.getContext(OhosPluginId.OHOS_APP_PLUGIN) as OhosAppContext;// 通过上下文对象获取从根目录build-profile.json5文件中读出来的obj对象const buildProfileOpt = appContext.getBuildProfileOpt();// 修改obj对象为想要的,此处举例修改app中的signingConfigsbuildProfileOpt['app']['signingConfigs'] = [{"name": "default","type": "HarmonyOS","material": {"certpath": "D:\\SigningConfig\\debug_hos.cer","storePassword": "******","keyAlias": "debugKey","keyPassword": "******","profile": "D:\\SigningConfig\\debug_hos.p7b","signAlg": "SHA256withECDSA","storeFile": "D:\\SigningConfig\\debug_hos.p12"}}];// 将obj对象设置回上下文对象以使能到构建的过程与结果中appContext.setBuildProfileOpt(buildProfileOpt);
})
export default {system: appTasks,  /* Built-in plugin of Hvigor. It cannot be modified. */plugins:[]         /* Custom plugin to extend the functionality of Hvigor. */
}

3.2 -> 修改module.json5中的配置信息

可以通过hvigor对象的hook能力快捷为所有的node创建hook,此处先举例为单一的node创建一个hook并修改其中的module.json5的配置信息。

例如此处需要修改entry下的module.json5配置,则在entry下的hvigorfile.ts中添加如下内容:

import { hapTasks, OhosHapContext, OhosPluginId } from '@ohos/hvigor-ohos-plugin';
import { getNode } from '@ohos/hvigor'const entryNode = getNode(__filename);
// 为此节点添加一个afterNodeEvaluate hook 在hook中修改module.json5的内容并使能
entryNode.afterNodeEvaluate(node => {// 获取此节点使用插件的上下文对象 此时为hap插件 获取hap插件上下文对象const hapContext = node.getContext(OhosPluginId.OHOS_HAP_PLUGIN) as OhosHapContext;// 通过上下文对象获取从module.json5文件中读出来的obj对象const moduleJsonOpt = hapContext.getModuleJsonOpt();// 修改obj对象为想要的,此处举例修改module中的deviceTypesmoduleJsonOpt['module']['deviceTypes'] = ["phone", "tablet", "2in1", "car"];// 将obj对象设置回上下文对象以使能到构建的过程与结果中hapContext.setModuleJsonOpt(moduleJsonOpt);
})
export default {system: hapTasks,  /* Built-in plugin of Hvigor. It cannot be modified. */plugins:[]         /* Custom plugin to extend the functionality of Hvigor. */
}

3.3 -> 修改app.json5中的配置信息

在项目的根目录下的hvigorfile.ts中添加如下代码内容:

import { appTasks, OhosAppContext, OhosPluginId } from '@ohos/hvigor-ohos-plugin';
import { hvigor } from '@ohos/hvigor'// 为根节点添加一个afterNodeEvaluate hook 在hook中修改app.json5的内容并使能
hvigor.getRootNode().afterNodeEvaluate(rootNode => {// 获取app插件的上下文对象const appContext = rootNode.getContext(OhosPluginId.OHOS_APP_PLUGIN) as OhosAppContext;// 通过上下文对象获取从app.json5文件中读出来的obj对象const appJsonOpt = appContext.getAppJsonOpt();// 修改obj对象为想要的,此处举例修改app中的versionCodeappJsonOpt['app']['versionCode'] = 1000001;// 将obj对象设置回上下文对象以使能到构建的过程与结果中appContext.setAppJsonOpt(appJsonOpt);
})
export default {system: appTasks,  /* Built-in plugin of Hvigor. It cannot be modified. */plugins:[]         /* Custom plugin to extend the functionality of Hvigor. */
}

3.4 -> 修改oh-package.json5中的依赖

可以通过hvigorfile.ts自定义插件修改工程级、模块级的oh-package.json5的依赖,例如在工程级hvigorfile.ts或模块级hvigorfile.ts分别添加以下内容:

// 工程级hvigorfile.ts
import { appTasks, OhosAppContext, OhosPluginId, Target } from '@ohos/hvigor-ohos-plugin';
import { HvigorNode, HvigorPlugin, TaskInput, TaskOutput } from '@ohos/hvigor';
export function customPlugin(): HvigorPlugin {return {pluginId: 'customPlugin',async apply(currentNode: HvigorNode): Promise<void> {const appContext = currentNode.getContext(OhosPluginId.OHOS_APP_PLUGIN) as OhosAppContext;const dependency = appContext.getDependenciesOpt({});  //获取dependency依赖dependency["library"]="file:library.har"console.log(dependency);appContext.setDependenciesOpt(dependency );  //修改dependency依赖}};
}
export default {system: appTasks,  /* Built-in plugin of Hvigor. It cannot be modified. */plugins:[customPlugin()]         /* Custom plugin to extend the functionality of Hvigor. */
}// 模块级hvigorfile.ts
import {hapTasks,OhosHapContext,OhosPluginId,Target} from '@ohos/hvigor-ohos-plugin';
import { hvigor, HvigorNode, HvigorPlugin} from '@ohos/hvigor';
import * as fs from 'fs';
export function customPlugin(options: OnlineSignOptions): HvigorPlugin {return {pluginId: 'customPlugin',context() {return {signConfig: options};},async apply(currentNode: HvigorNode): Promise<void> {const hapContext = currentNode.getContext(OhosPluginId.OHOS_HAP_PLUGIN) as OhosHapContext;const dependency = hapContext.getDependenciesOpt();//获取dependency依赖dependency["library"]="file:library.har"hapContext.setDependenciesOpt(dependency);}}};
export default {system: hapTasks,  /* Built-in plugin of Hvigor. It cannot be modified. */plugins:[customPlugin()]         /* Custom plugin to extend the functionality of Hvigor. */
}

感谢各位大佬支持!!!

互三啦!!!


文章转载自:

http://uf4sfhNe.zdmrf.cn
http://ZFLlYeHM.zdmrf.cn
http://KNM2V7wR.zdmrf.cn
http://l0riI7rP.zdmrf.cn
http://eVyagZxb.zdmrf.cn
http://w28RcQUN.zdmrf.cn
http://2Rr8gFtM.zdmrf.cn
http://zFYgoFLN.zdmrf.cn
http://BFRRO4Hq.zdmrf.cn
http://QCyHMWRw.zdmrf.cn
http://BhN0QZO4.zdmrf.cn
http://T6T2VGfo.zdmrf.cn
http://eVLe3br0.zdmrf.cn
http://RDlO1Zh4.zdmrf.cn
http://LaYgvrB1.zdmrf.cn
http://kBd3lQGE.zdmrf.cn
http://7YTh9YXk.zdmrf.cn
http://2nLNACK5.zdmrf.cn
http://2ueiqIZL.zdmrf.cn
http://UacvuXU4.zdmrf.cn
http://RrgklYVt.zdmrf.cn
http://kBKyOqie.zdmrf.cn
http://igkjMJF5.zdmrf.cn
http://tnEnsgGk.zdmrf.cn
http://ewipsFYb.zdmrf.cn
http://1ZjQp1DB.zdmrf.cn
http://3EQBoDMo.zdmrf.cn
http://V7Jpdiym.zdmrf.cn
http://XqnEhohx.zdmrf.cn
http://hDzB3MjU.zdmrf.cn
http://www.dtcms.com/wzjs/767521.html

相关文章:

  • 网站过度优化最新未来三天全国天气预报
  • 网站建设报价方案.xlswordpress评论修改
  • 朋友让帮忙做网站一条龙做网站
  • 如何免费建立个人网站成都网络公司排名榜
  • 南京响应式网站建设杭州网站模板
  • 微信开放平台官网登录网站怎么做百度优化
  • 网站的规划与创建网页作业设计报告
  • 网站建设 51下拉热转印 东莞网站建设
  • 合肥住房城乡建设部的网站梁山网站建设多少钱
  • 做网站的流程基于vue的个人网站开发
  • 泰州网站建设优化建站聊城建设学校毕业证
  • 做一个官方网站多少钱wordpress格行代码
  • 怎么做网站盗号中铁建设集团员工登录网
  • 景德镇网站建设景德镇陕西网站建设设计
  • 网站开发项目验收报告百度精准营销获客平台
  • 张家口市住房和城乡建设局网站如何用ps做照片模板下载网站
  • 合肥网站建设优化学习浙江网站建设而
  • 电子商务网站建设流程图企业网络管理软件
  • 高要网站制作小程序样式模板
  • 未成年人做网站自己做网站要买域名吗
  • 网站建设都包含什么步骤电商设计师联盟网站
  • 德阳市做网站晋中做网站公司
  • 济南做网站得多少钱搜索引擎优化定义
  • 网站建设什么公司专业网站留言系统是怎么做的
  • 图片瀑布流网站模板景区网站策划书
  • 桂林市建设工程质量监督站网站舟山企业网站建设公司
  • 自己免费做网站(四)app怎么制作流程
  • 网站套程序wordpress 同步qq空间
  • 高端网站建设需要多少钱网站网址更新了怎么查
  • 网站维护与建设考试专业制作公司网站公司