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

网站怎么做内链外链wordpress伪原创插件

网站怎么做内链外链,wordpress伪原创插件,建网站图片怎么找,seo是什么职位的缩写Hvigor允许开发者实现自己的插件,开发者可以定义自己的构建逻辑,并与他人共享。Hvigor主要提供了两种方式来实现插件:基于hvigorfile脚本开发插件、基于typescript项目开发。下面以基于hvigorfile脚本开发插件进行介绍。 基于hvigorfile脚本…

Hvigor允许开发者实现自己的插件,开发者可以定义自己的构建逻辑,并与他人共享。Hvigor主要提供了两种方式来实现插件:基于hvigorfile脚本开发插件、基于typescript项目开发。下面以基于hvigorfile脚本开发插件进行介绍。

基于hvigorfile脚本开发

基于hvigorfile.ts脚本开发的方式,其优点是可实现快速开发,直接编辑工程或模块下hvigorfile.ts即可编写插件代码,不足之处是在多个项目中,无法方便的进行插件代码的复用和共享分发。

  1. 导入模块依赖。
// 导入接口
import { HvigorPlugin, HvigorNode } from '@ohos/hvigor'
  1. 编写插件代码。
    在hvigorfile.ts中定义插件方法,实现HvigorPlugin接口。
// 实现自定义插件
function customPlugin(): HvigorPlugin {return {pluginId: 'customPlugin',apply(node: HvigorNode) {// 插件主体console.log('hello customPlugin!');}}
}
  1. 在导出声明中使用插件。
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/hvigor'function 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\n'for (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/hvigor'function 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.yayakq.cn/news/209277/

相关文章:

  • 旅游网站的后台管理系统怎么做抓取微博 Wordpress
  • 企业网站的步骤网站域名到期怎么续费
  • 网门网站下载地址网站建设实训总结
  • 网站内容采编怎么做wordpress怎么换log
  • 网站不备案可以用吗网站要放备案号吗
  • 开发中英文切换网站如何做哪个网站有学做吃的
  • 用jsp做的网站代码网站开发一般黄了
  • 无忧网站建设多少钱刷网页赚钱
  • 广州专业网站制作设计佛山做礼物的网站
  • 阿克苏建设局网站外贸网站建设论坛
  • 做网站需要准备哪些东西全国最好装修公司排行榜
  • 大型网站响应式通付盾 网站建设公司
  • 温州做网站技术员怎么线上注册公司
  • 有没有在线制作app网站开发平台网站投注员怎么做
  • 做二手网站赚钱不排版设计工作内容
  • php建设网站教程海西网站建设
  • 百度的网站名外包公司为什么没人去
  • seo站长博客荣耀手机商城官方网站售后
  • 搭建专业网站服务器php调用网站导航怎么弄
  • 网站流量分成深圳优化服务
  • 成华区微信网站建设深圳软件定制
  • 网站建设的违约责任怎么写北京到安阳火车时刻表
  • 建设银行无锡分行招聘网站做网站的价钱
  • 手机网站设计软件临沂市兰山区建设局网站
  • 便宜购 网站建设大连做网站的
  • 佛山网站建设及优化公司欧美做的爱爱网站
  • 百度收录申请南通优化网站公司哪家好
  • 制作网站需要多少时间做房产经纪人要自己花钱开网站吗
  • app开发和网站建设区别农村小工厂暴利
  • wordpress拖动建站google网站排名