cdn 方式构建的 vue 项目怎么自定义组件及复用

2020-11-22 20:33:12 +08:00
 TmacV2

用脚手架的项目,.vue 单组件文件可以导入实现复用。 那 cdn 方式的项目怎么搞? 想了想可以把组件选项写在 js 文件中 然后用到的时候引用一下 js 文件进行组件注册?

3197 次点击
所在节点    Vue.js
31 条回复
VtoExtension
2020-11-22 20:40:59 +08:00
写过一个 Demo,太不习惯了,除非以后插件支持
gitee.com/cloudfile/chat-vue/blob/master/src/components.js
TmacV2
2020-11-22 20:45:27 +08:00
a.js

function Test() {
return {
template: '<div @click="handle">{{data}}</div>',
data: function () {
return {
data: 1
};
},
methods: {
handle(){
this.data+=5;
}
}
}
}

index.html

<div id="app">
<Child></Child>
</div>
<script>
// 注册
var Child = Test();
Vue.component('course-sort', Test())
// 创建根实例
new Vue({
el: '#app',
components: {
Child
}
})
</script>
TmacV2
2020-11-22 21:14:19 +08:00
@VtoExtension 老铁 你这里面用了 es6 语法吧
runze
2020-11-22 21:18:52 +08:00
galikeoy
2020-11-22 21:22:00 +08:00
呃呃呃,我们是 cli 打包,然后把资源扔到 cdn 上面去
mxT52CRuqR6o5
2020-11-22 21:24:22 +08:00
是要古老一点的模块解决方案吗? seajs 或 requirejs
TmacV2
2020-11-22 22:01:32 +08:00
@runze 6666
TmacV2
2020-11-22 22:01:46 +08:00
@mxT52CRuqR6o5 感谢 新手了解一下
TmacV2
2020-11-22 22:04:38 +08:00
@galikeoy 额 这个编译好放在本地没区别呀
galikeoy
2020-11-22 23:00:27 +08:00
@TmacV2 #9 是啊,就是本地编译完扔 cdn
beginor
2020-11-23 08:32:47 +08:00
手写 AMD 模块, 用 require.js 或者 system.js 来加载。

或者直接写 es6 模块, 直接 import, 兼容性差点
HiCode
2020-11-23 09:20:52 +08:00
大部分前端都是编译好后放到 cdn ;

假定你不想要编译,在 html 页面中直接加载使用 vue 组件,可以参考下面项目:
https://gitee.com/tengzhinei/Vue-rap

https://gitee.com/haimadongli001/jQuery.Vue.js
TmacV2
2020-11-23 11:57:49 +08:00
@HiCode 十分感谢
TmacV2
2020-11-23 18:21:09 +08:00
@HiCode 已经用上了 真香
HiCode
2020-11-23 22:47:51 +08:00
@TmacV2 我已经用在十几个 H5 项目中,老实说这样来开发效率高,执行效率也不算太低,没有太大的性能损耗。
TmacV2
2020-11-24 07:56:46 +08:00
你用了 Vue-rap 还是 jQuery.Vue.js ?
TmacV2
2020-11-24 08:36:53 +08:00
@HiCode 看你的头像发现第二个项目是你的 xd 🤒
HiCode
2020-11-24 09:12:58 +08:00
@TmacV2 我一开始打算用 Vue-rap,学习一段时间后重构了 jQuery.Vue.js 自用。
TmacV2
2020-11-24 09:39:01 +08:00
@HiCode 哈哈哈 啥时候能支持一下嵌套理由 我跳转到 demo 里 temp 组件里 然后下面有菜单 根据菜单显示子路由 view https://i.loli.net/2020/11/24/6N9qiBDTlJeFpnr.jpg
TmacV2
2020-11-24 11:01:09 +08:00
@HiCode 你的项目里如果有没有需要一个页面根据不同标签页切换显示不同的 view 有的话你要怎么实现。
看了一下 vue-rap 项目 demo 的实例



https://i.loli.net/2020/11/24/2TWwhqMQGSrvPEz.jpg

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/728117

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX