综上,在 Vue 1.x 里不存在预编译的概念,所以想动态修改模板还是有许多方式的,甚至还可以结合slot/slot取到slot里的内容拼接进模板里。但 2.0 就麻烦了,并找不到理想的方法。
这种方式就略显蛋疼,而且效率最差。 interpolate 也是我最开始做动态渲染模板想到的方式,不推荐使用。
3、 你如果想念一个人就会变成微风,轻轻掠过他的身边。就算他感觉不到,可这就是你全部的努力。人生就是这样子,每个人都变成各自想念的风。
例如要做一个类 select 的组件,用户传入 options 数据,通过 value prop 获取选中值,最基本的原型如下◆。
我们知道 Vue 在内部帮我们做了许多优化j9九游会-真人游戏第一品牌,但是在这里可能会由于某些优化导致动态拼接的模板无法渲染成功。例如这里我们不使用 v-for 而是手工遍历 options 生成需要的 HTML
这篇文章主要介绍了Vue中如何动态添加模板的相关知识,内容详细易懂,操作简单快捷尊龙凯时ag旗舰厅Vue中如何动态添加模板。,具有一定借鉴价值,相信大家阅读完这篇Vue中如何动态添加模板文章都会有所收获,下面我们一起来看看吧。
按照这样的思路,其实可以让用户传入的模板预先编译好,传入到组件内,拼接 DOM tree 看起来也能解决问题尊龙凯时ag旗舰厅尊龙凯时ag旗舰厅Vue中如何动态添加模板。。那么可以这么玩。
使用 partials 也能达到添加自定义模板的目的,但是通常的做法是要全局注册 partial,这么做并不优雅◆。 vue-strap 就是这么做的。如果重名了会被覆盖(初次渲染不会,
通过打印组件对象可以获得一个信息,在$options里定义了一个 template 属性,写在 template 标签里的模板,最终编译后也会在 $options.template 里◆。通过文档的生命周期 可以得知,在 created 的时候j9九游会 - 真人游戏第一品牌, 实例已经结束解析选项, 但是还没有开始 DOM 编译 也就是说,如果用户通过 prop 的数据我们可以获得,但是模板其实还没有渲染成 DOM。经过测试,在created修改this.$options.template是可以改变最终生成的 DOM 的,同时也能拿到 props 的内容。
目前并没有找到合适的解决方案。2.0 的 Vue 将 compile 工作提前,并且 compiler 也是单独一个包(除非你直接引用的是 vue.js 文件,包含 compiler 和 runtime,那么第一种方法是适用的),那么并不能动态的生成模板◆。除非用户传入的是 render 能识别的 DOM tree◆。
关于“Vue中如何动态添加模板”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Vue中如何动态添加模板”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道◆◆。
这样我们就可以开发让用户自定义布局的组件了,用户传入布局参数,通过手工拼接模板,设置了_linkerCachable = false也不会被缓存◆◆。
如果此时需要增加一个 API 支持让用户自定义 option 部分的模板。此处用 slot 并不能解决问题。