这篇“vue父子模版嵌套如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue父子模版嵌套如何实现”文章吧。
第一种,子组件模版直接写在js里
//定义模版挂载点my-component <div id="exampleBox1"> <com-ponent></com-ponent> </div> <script src="../vue/node_modules/vue/dist/vue.js"></script> <script> var Component = Vue.extend({// 定义 template: '<div>A custom component!</div>', data: function () { return { name: 'yuxie' } } }); Vue.component('com-ponent', Component);// 注册 //注意,extend(json) 和 vue.component('com-ponent', json)//这两个JSON是相等的。 //所以下面第二种会将extend()函数省略掉,直接在component中定义,系统会自动调用extend函数。 var conp = new Vue({// 创建根实例 el: '#exampleBox1' }); </script>
第二种,使用HTML模版
<!-- 父组件模板 --> <div id="exampleBox2" > <div>{{parent.name}}</div> <!--模版挂载标识--> <children></children> </div> <!-- 子组件模板 --> <template id="child-template"> <p >{{text}}</p> </template> <script> Vue.component('children', {//child是模版挂载的标签名 template: '#child-template',//id对应子组件的ID data: function () { return { text: '这里是子组件的内容' } } }); var parent = new Vue({// 初始化父组件 el: '#exampleBox2', data: { parent: { name:'这里是父组件的内容' } } }) </script>
第三种、来一个复杂的
<div id="example"> <!-- 所有的模板挂件,都必须在根实例ID内部,否则找不到挂件 --> <my-component></my-component> <!-- 模版可以重用多次 ···· 只不过一样的东西没有这个必要 --> <child></child>复用一次 <child></child>复用二次 <child></child> ··· <child></child> ··· </div> <!--比如放在这里是找不到的--> <child></child> <script src="../vue/node_modules/vue/dist/vue.js"></script> <script> //定义子组件,子组件必须在父组件之前定义。 var Child = Vue.extend({template: '<div>A child component!</div>'}); //定义父组件 var Parent = Vue.extend({ template: '<div >Parent<child-component></child-component>父模版内部</div>', components: { // 调用子组件 'child-component': Child } }); // 注册父组件 Vue.component('my-component', Parent); //复用子组件。 Vue.component('child', Child); // 创建根实例,所有组件都需要在根实例之前创建。 new Vue({ el: '#example' }) </script>
Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。
以上就是关于“vue父子模版嵌套如何实现”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。