鹅鹅鹅鹅
鹅鹅鹅鹅
  • 发布:2021-09-22 19:26
  • 更新:2024-04-09 10:49
  • 阅读:17120

引用超级全局组件方案

分类:uni-app

vue-inset-loader

编译阶段在sfc模板指定位置插入自定义内容,适用于webpack构建的vue应用,常用于小程序需要全局引入组件的场景。(由于小程序没有开放根标签,没有办法在根标签下追加全局标签,所以要使用组件必须在当前页面引入组件标签)

github:https://github.com/1977474741/vue-inset-loader
用得上顺便点个star

第一步 安装

npm install vue-inset-loader --save-dev  

第二步 vue.config.js注入loader

module: {  
    rules: [  
      {  
        test: /\.vue$/,  
        use:{  
            loader: "vue-inset-loader"  
            // // 针对Hbuilder工具创建的uni-app项目  
            // loader: path.resolve(__dirname,"./node_modules/vue-inset-loader")  
        }  
      }  
    ]  
},  
// 支持自定义pages.json文件路径  
// options: {  
//     pagesPath: path.resolve(__dirname,'./src/pages.json')  
// }  

第三步 pages.json配置文件中添加insetLoader

"insetLoader": {  
    "config":{  
        "confirm": "<BaseConfirm ref='confirm'></BaseConfirm>",  
        "abc": "<BaseAbc ref='BaseAbc'></BaseAbc>"  
    },  
    // 全局配置  
    "label":["confirm"],  
    "rootEle":"div"  
},  
"pages": [  
    {  
        "path": "pages/tabbar/index/index",  
        "style": {  
            "navigationBarTitleText": "测试页面",  
            // 单独配置,用法跟全局配置一致,优先级高于全局  
            "label": ["confirm","abc"],  
            "rootEle":"div"  
        }  
    },  
]  

配置说明

  • config (default: {})
    定义标签名称和内容的键值对
  • label(default: [])
    需要全局引入的标签,打包后会在所有页面引入此标签
  • rootEle(default: "div")
    根元素的标签类型,缺省值为div,支持正则,比如匹配任意标签 ".*"

    labelrootEle 支持在单独页面的style里配置,优先级高于全局配置

11 关注 分享
木杉丶 期许_ snakelzero 霍霍 1***@qq.com 3***@qq.com 3***@qq.com px15229 DCloud_UNI_HRK 正月的阳光 x***@163.com

要回复文章请先登录注册

1***@qq.com

1***@qq.com

vite构建的怎么用呢
2023-10-12 15:22
鹅鹅鹅鹅

鹅鹅鹅鹅 (作者)

回复 ijiangruyi :
不行,这个小程序本身做不到
2023-09-22 10:33
ijiangruyi

ijiangruyi

这个是每个页面都一个实例吗,如果需要多个页面共享一个实例可以吗?
2023-09-22 09:48
px15229

px15229

秀!学习下
2023-09-13 17:18
鹅鹅鹅鹅

鹅鹅鹅鹅 (作者)

回复 1***@qq.com :
app确实加了判断,只在微信小程序内才有效,因为我觉得可能app用不到,非要用的话你可以在源码里把那个判断拿掉就好了
2023-07-05 10:38
1***@qq.com

1***@qq.com

这个app用不了呀。。实测
2023-07-04 15:50
鹅鹅鹅鹅

鹅鹅鹅鹅 (作者)

回复 翻滚吧牛欢喜 :
没有任何区别
2023-05-31 11:16
翻滚吧牛欢喜

翻滚吧牛欢喜

请问这个工具和用代码在页面写入<BaseConfirm ref='confirm'></BaseConfirm>这样有什么区别呢
2023-05-30 23:07
鹅鹅鹅鹅

鹅鹅鹅鹅 (作者)

回复 s***@foxmail.com :
在开发者工具看下dom里有没有成功插入标签
2023-05-25 18:54
s***@foxmail.com

s***@foxmail.com

$refs中没有 全局注册的组件
2023-05-25 09:42