IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 小程序:如何做一个全局组件 -> 正文阅读

[JavaScript知识库]小程序:如何做一个全局组件

文章目录

问题

在我们开发小程序过程中,如果想像 vue 一样使用全局组件是不行的,必须将组件一个一个引入到响应的页面,这是因为小程序每个页面都是一个线程,没有像 vue 那种有顶级的 dom。

那么如果我们想做一个全局组件又不想每个页面都分别引入该怎么办呢,那就只能尽可能的让我们引入的过程自动化了。

实践

比如我们做一个全局的 loading,不想每个页面都手动引入,可以写相关的自动化脚本,来将代码引入到 .wxml 里面。

代码结构

- generator
	// 相关自动化脚本
	- index.js
	// 模板
	- template
		- components
			- custom-loading
				- index.js
				- index.wxml
				- index.wxss
				- index.json

template 文件中使我们的模板,也就是我们的 custom-loading 组件(这个我就不代码演示了),然后我们可以把这个模板直接注入到我们的代码中,并且自动化的加上引入组件的代码。

那么接下来我们主要看看 index.js 做了什么,主要分为两个部分:

  1. template 中的文件注入到项目中
  2. 给 app.json 中引入全局组件 custom-loading
  3. 在每个 pages 的 index.wxml 引入组件

先来看看 2 的代码:

const fs = require('fs')
const entryFilePath = './app.json'
// 是否有该文件
if (fs.statSync(entryFilePath)) {
  const { EOL } = require('os')
  // 读取app.json文件内容
  const contentMain = fs.readFileSync(api.resolve(entryFilePath), { encoding: 'utf-8' })
  // 先看是不是已经有了这个custom-loading
  const customLoadingReg = /['"]?custom-loading['"]?:/
  // 拿到app.json每一行
  const contentMainLines = contentMain.split(/\r?\n/g)
  // 拿到usingComponents
  const usingComponentsStartReg = /['"]?usingComponents['"]?:/
  // 检测usingComponents所在的下标
  const usingComponentLineNum = contentMainLines.findIndex(line => line.match(usingComponentsStartReg))
  // 检测tabbar
  const tabBarStartReg = /['"]?tabBar['"]?:/
  // 页面中是否已经有了custom-loading
  if (!customLoadingReg.test(contentMain)) {
      // 如果没有的话,就找tabbar,放在后面
	  if(usingComponentLineNum < 0) {
	    const tabBarLineNum = contentMainLines.findIndex(line => line.match(tabBarStartReg))
	    contentMainLines[tabBarLineNum - 1] += `${EOL}  usingComponents: { "custom-loading": "./components/custom-loading/index" },`
	  } else {
	    contentMainLines[usingComponentLineNum] += `${EOL}    "custom-loading": "./components/custom-loading/index",`
	  }
	  fs.writeFileSync(path.resolve(entryFilePath), contentMainLines.join(EOL), { encoding: 'utf-8' })
	}
} else {
  log(`app.wpy 不存在`)
}

接下来是 3 相关代码:

// 读取app.json文件内容
const contentMain = fs.readFileSync(api.resolve(entryFilePath), { encoding: 'utf-8' })
// pages开始,逗号结尾的部分
const pageConfigReg = /['"]?pages['"]?: \[([^\]]+)\],/
// 将pages按照逗号分隔为数组
const pageList = pageConfigReg.exec(contentMain)[1].replace(/\s+/, '').replace(/\n\s+/g, '').split(',')

pageList.forEach((pagePath) => {
  // 进入每个pagePath并加入该组件<custom-loading />
})

总结

当我们遇到一些需要重复工作的问题,可以尝试用 node 文件读写的这个思路来解决。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-16 11:16:35  更:2022-05-16 11:18:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:01:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码