HTML中创建vue组件的方法有哪些?
Admin 2021-10-30 群英技术资讯 925 次浏览
这篇文章给大家分享的是HTML中创建vue组件的方法,下文的几种方法示例中,除了有创建vue组件的操作还有调用创建vue组件的操作,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
方法一:Vue.extend( options )
// 借用官网的例子,小小改动了一下 // 在父组件中,创建一个子组件,并调用 <div id='app'> <button>{{message}}</button> <div id="mount-point"></div> </div> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el:"#app", data:{ message:'父组件' }, }); // 创建构造器 var Profile = Vue.extend({ template: '<p>{{firstName}} {{lastName}} {{alias}}</p>', data: function () { return { firstName: 'N', lastName: 'H', alias: 'Y' } } }) // 创建 Profile 实例,并挂载到一个元素上。 new Profile().$mount('#mount-point') </script>
方法二:Vue.component( id, [definition] ) + Vue.extend( options )
用法:Vue.component()注册或获取全局组件。注册还会自动使用给定的 id 设置组件的名称
<div id="app"> <!-- 如果要使用组件,直接把组件的名称以 HTML 标签的形式,引入到页面中--> <todo :todo-data="todoList"></todo> </div> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script type="text/javascript"> // 构建一个子组件 var todoItem = Vue.extend({ template: ` <li> {{ text }} </li> `, props: ['text'] }) // 构建一个父组件 var todoWarp = Vue.extend({ template: ` <ul> <todo-item v-for="(item, index) in todoData" v-text="item.text"></todo-item> </ul> `, props: ['todoData'], // 局部注册子组件 components: { //使用 components 定义组件时,若组件名称使用驼峰命名,则在引用组件时,需要把大写改为小写,并且用'-'将单词连接 todoItem: todoItem } }) // 注册到全局 Vue.component('todo', todoWarp) // 等同于下面这种写法 Vue.component('todo',Vue.extend({ template : 'xxx', props:[xxx], components:'xxx' })) new Vue({ el: '#app', data: { todoList: [ { id: 0, text: '工作' }, { id: 1, text: '学习' }, { id: 2, text: '休息' } ] } }) </script>
方法三:直接使用Vue.component()
<div id="app"> <mycom></mycom> </div> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script type="text/javascript"> Vue.component('mycom',{ template : '<h3>这是使用 Vue.component 创建的组件</h3>' }) new Vue({ el: '#app' }) </script>
但是这样写会有一个问题:在h3标签后出现另一个标签,就会出问题,
Vue.component('mycom',{ template : '<h3>这是使用 Vue.component 创建的组件</h3><h3>这是使用 Vue.component 创建的组件</h3>' })
方法四:使用Vue.component()
在被控制的 #app 外面使用 template 元素,定义组建的HTML模板结构
<div id="app"> <mycom></mycom> </div> <template id="tem1"> <h1>这是 template 元素</h1> </template> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script type="text/javascript"> Vue.component('mycom', { template: '#tem1' }); new Vue({ el: '#app' }) </script>
方法五:使用Vue.component() + is
<div id="app"> <ul> <li is="todo-item" v-for="(todo,index) in todos " :title="todo" :key="index" @remove="removeTodo(index)"></li> </ul> </div> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script type="text/javascript"> Vue.component('todo-item', { template: ` <li> {{title}} <button @click="$emit('remove')">remove</button> </li> `, props: ['title'] }) new Vue({ el: "#app", data: { todos: ["eating", "swimming", "reading"] }, methods: { removeTodo: function (index) { this.todos.splice(index, 1) } } })
补充说明一下is属性:
有些 HTML 元素,诸如 ul、ol、table 和 select,对于可以出现在其内部元素是有严格限制的。而有些元素,诸如 li、tr 和 option,只能出现在特定的元素内部。这会导致我们使用这些有约束条件的元素时遇到一些问题。例如
<table> <blog-post-row></blog-post-row> </table>
这个自定义组件 会被作为无效的内容提升到外部,并导致最终渲染结果出错。幸好这个特殊的 is attribute 给了我们一个变通的办法:
<table> <tr is="blog-post-row"></tr> </table>
关于HTML中创建和调用vue组件的方法就介绍到这,上述实例具有一定的借鉴价值,感兴趣的朋友可以参考,希望能对大家有帮助,想要了解更多大家可以关注其它的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了前端的状态管理,续上篇文章内容,今天将从 Redux 入手逐渐拓展,需要的小伙伴可以参考一下哟
这篇文章主要介绍了前端JavaScript多数元素的算法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
这篇文章主要给大家分享用vue框架实现简单的计数器,也就是在给定的数字范围可以增加或者减少数字,超出范围就提示,下文有实现代码和效果,感兴趣的朋友可以参考,接下来我们一起来学习一下吧。
在JavaScript 中,我们往往会遇到需要使用某些默认值来填充数组的情况,那么都有哪些方式可以完成这样的任务呢?这篇文章主要给大家介绍了关于JS创建或填充任意长度数组的小技巧,需要的朋友可以参考下
Vue Router是Vue.js (opens new window)官方的路由管理器,它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌,这篇文章主要给大家介绍了关于vue3使用vue-router的相关资料,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008