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

新型门窗网站模板apache wordpress 伪静态

新型门窗网站模板,apache wordpress 伪静态,wordpress主题下载失败,网上的彩票网站是怎么做的Hvigor允许开发者实现自己的插件#xff0c;开发者可以定义自己的构建逻辑#xff0c;并与他人共享。Hvigor主要提供了两种方式来实现插件#xff1a;基于hvigorfile脚本开发插件、基于typescript项目开发。下面以基于hvigorfile脚本开发插件进行介绍。 基于hvigorfile脚本…Hvigor允许开发者实现自己的插件开发者可以定义自己的构建逻辑并与他人共享。Hvigor主要提供了两种方式来实现插件基于hvigorfile脚本开发插件、基于typescript项目开发。下面以基于hvigorfile脚本开发插件进行介绍。 基于hvigorfile脚本开发 基于hvigorfile.ts脚本开发的方式其优点是可实现快速开发直接编辑工程或模块下hvigorfile.ts即可编写插件代码不足之处是在多个项目中无法方便的进行插件代码的复用和共享分发。 导入模块依赖。 // 导入接口 import { HvigorPlugin, HvigorNode } from ohos/hvigor编写插件代码。 在hvigorfile.ts中定义插件方法实现HvigorPlugin接口。 // 实现自定义插件 function customPlugin(): HvigorPlugin {return {pluginId: customPlugin,apply(node: HvigorNode) {// 插件主体console.log(hello customPlugin!);}} }在导出声明中使用插件。 export default {system: appTasks,plugins:[customPlugin() // 应用自定义Plugin] }使用hvigorfile插件动态生成navigation防混淆文件 我们在使用navigation的系统路由表时每次添加新页面都需要配置一下release环境防混淆。若将这些页面放在一个固定的目录下则与我们的模块化设计相违背若命名使用固定的前缀或后缀总感觉有点多余手动一个一个的添加虽然符合我们的代码规范设计但就是有点繁琐。有没有更方便的方式来处理这个混淆配置呢 其实我们可以在写一个hvigorfilew插件来自动生成混淆配置文件。我们自定义一个HvigorPlugin任务通过OhosHapContext对象读取module.json5文件中的routerMap字段可以获取系统路由表的名称再读取profile目录下的路由表。解析json文件内存并将页面路径写到一个混淆文件中这样每次编译时自动生成防混淆文件我们只需要引入这个文件就可以了。示例如下 import { hapTasks, OhosHapContext, OhosPluginId } from ohos/hvigor-ohos-plugin import { HvigorPlugin, HvigorNode, FileUtil } from ohos/hvigorfunction parseRouterMap(): HvigorPlugin {return {pluginId: parseRouterMap,apply(node: HvigorNode) {const hapCtx node.getContext(OhosPluginId.OHOS_HAP_PLUGIN) as OhosHapContextconst moduleJson hapCtx.getModuleJsonOpt()const routerMapName moduleJson[module][routerMap].split(:)[1]const dir hapCtx.getModulePath()const srcFile FileUtil.pathResolve(dir, src, main, resources, base, profile, ${routerMapName}.json)const json FileUtil.readJson5(srcFile)const routerRuleFile FileUtil.pathResolve(dir, obfuscation-router.txt)FileUtil.ensureFileSync(routerRuleFile)const routerMapArray json[routerMap]let rules -keep-file-name\nfor (const element of routerMapArray) {const pageSourceFile element[pageSourceFile]const path pageSourceFile.substring(0, pageSourceFile.lastIndexOf(.))rules ${path}\n}FileUtil.writeFileSync(routerRuleFile, rules)}} }export default {system: hapTasks,plugins:[parseRouterMap()] }编译后会在entry目录下生成obfuscation-router.txt防混淆文件只要引入这个文件就可以了。 使用hvigorfile插件动态生成navigation页面枚举名称 我们在我们navigation的push跳转到新页面时都得提前定义好系统路由表中的页面name因为使用的name与系统路由表中定义的name不相同时跳转页面则会白屏。有了前面的经验其它我们也可以动态生成一个ets文件将系统路由表中的页面名称自动生成一个枚举这样就不用每次配置系统路由表还是复制一下名称了。例如我们的系统路由表是这样的 {routerMap: [{name: dialog,pageSourceFile: src/main/ets/pages/dialog/DialogPage.ets,buildFunction: dialogBuilder},{name: web,pageSourceFile: src/main/ets/pages/web/WebPage.ets,buildFunction: webBuilder},{name: login,pageSourceFile: src/main/ets/pages/login/LoginPage.ets,buildFunction: loginBuilder}] }我们现在实现一个hvigorfile插件来解析系统路由表中的name字段并生成对应的枚举值。示例如下 import { hapTasks, OhosHapContext, OhosPluginId } from ohos/hvigor-ohos-plugin import { HvigorPlugin, HvigorNode, FileUtil } from ohos/hvigorfunction parseRouterMap(): HvigorPlugin {return {pluginId: parseRouterMap,apply(node: HvigorNode) {const hapCtx node.getContext(OhosPluginId.OHOS_HAP_PLUGIN) as OhosHapContextconst moduleJson hapCtx.getModuleJsonOpt()const routerMapName moduleJson[module][routerMap].split(:)[1]const dir hapCtx.getModulePath()const srcFile FileUtil.pathResolve(dir, src, main, resources, base, profile, ${routerMapName}.json)const json FileUtil.readJson5(srcFile)const routerMapFile FileUtil.pathResolve(dir, src, main, ets, Pages.ets)FileUtil.ensureFileSync(routerMapFile)const routerMapArray json[routerMap]let ss for (const element of routerMapArray) {const name element[name]ss ${name} ${name},\n}ss export enum Pages {\n${ss}}FileUtil.writeFileSync(routerMapFile, ss)}} }export default {system: hapTasks,plugins:[parseRouterMap()] }我们在ets目录下生成了一个Pages.ets文件并将所有navigation页面生成对应的枚举值页面跳转时使用这些枚举值就不怕出错了。Pages.ets内容如下 export enum Pages {dialog dialog,web web,login login, }
http://www.hkea.cn/news/14392944/

相关文章:

  • 网站开发涉及技术seo加盟代理
  • 大良网站建设服务网站开发的职责
  • 网站制作与网站建设实际报告中铁建设集团门户密码
  • 网站后台如何添加关键词黄山网站设计公司
  • 上门做美容的有什么网站在家做网站或ps挣钱接活
  • 教医学生做科研的网站有哪些seo专员工资一般多少
  • 焦作做网站的公司东莞外贸优化公司
  • 深圳建设厅网站官网北京小学大兴网站建设
  • wordpress图床推荐seo研究中心培训机构
  • 石家庄最新今天消息什么是seo营销
  • 宝安网站建设seo信科WordPress有时候快有时候慢
  • 做企业网站服务商h5手机网站建设
  • 深圳市坪山新区建设局网站wordpress评论邮箱
  • 龙华专业做网站浙江广厦建设职业技术学院网站
  • 做视频网站视频加载过慢乡镇卫生院网站建设模板
  • 宿松 做网站wordpress 空间推荐
  • 成品网站源码1深圳创业补贴去哪里申请
  • php创建网站动漫制作专业个人简历
  • dede 获取网站标题个体可以做企业网站吗
  • 制作商务网站信息标题应有没有帮忙做标书的网站
  • 做公司网站的必要性wordpress add_action()
  • 网站建设的付款方式wordpress代码执行
  • 网站建设现状和前景计算机大专生的出路
  • 哪个网站做阿里首页模板最新新闻热点事件2023
  • 请简述网站制作流程分销系统开发多少费用
  • 高淳做网站价格成都电脑培训班零基础
  • 怎么查看网站是asp还是php杭州网站建设开发有限公司
  • 旅游在哪个网站做攻略百度不收录哪些网站吗
  • 网站优化个人工作室网站网站制作多少钱
  • 网站建设与维护1997年广东网站建设哪家有