html中创建并调用vue组件的几种方法汇总
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要介绍了html中创建并调用vue组件的几种方法汇总,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
作者Echoyya
出处
最近在写项目的时候,总是遇到在html中使用vue.js的情况,且页面逻辑较多,之前的项目经验都是使用脚手架等已有的项目架构,使用.vue文件完成组价注册,及组件之间的调用,还没有过在html中创建组件的经验,所以借此机会学习一下。
方法一Vue.extend( options )
- 用法使用基础 Vue 构造器,创建一个“子类”。参数是一个包含组件选项的对象。data 选项是特例,需要注意 - 在 Vue.extend() 中它必须是函数
- extend 创建的是 Vue 构造器,而不是我们平时常写的组件实例,所以不可以通过 new Vue({ ponents: testExtend }) 来直接使用,需要通过 new Profile().$mount('selector选择器') 来挂载到指定的元素上。
- Vue.extend + vm.$mount 组合
// 借用官网的例子,小小改动了一下 // 在父组件中,创建一个子组件,并调用 <div id='app'> <button>{{message}}</button> <div id="mount-point"></div> </div> <script src="https://cdn.jsdelivr./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.ponent( id, [definition] ) + Vue.extend( options )
用法Vue.ponent()注册或获取全局组件。注册还会自动使用给定的 id 设置组件的名称
<div id="app"> <!-- 如果要使用组件,直接把组件的名称以 HTML 标签的形式,引入到页面中--> <todo :todo-data="todoList"></todo> </div> <script src="https://cdn.jsdelivr./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'], // 局部注册子组件 ponents: { //使用 ponents 定义组件时,若组件名称使用驼峰命名,则在引用组件时,需要把大写改为小写,并且用'-'将单词连接 todoItem: todoItem } }) // 注册到全局 Vue.ponent('todo', todoWarp) // 等同于狼蚁网站SEO优化这种写法 Vue.ponent('todo',Vue.extend({ template : 'xxx', props:[xxx], ponents:'xxx' })) new Vue({ el: '#app', data: { todoList: [ { id: 0, text: '工作' }, { id: 1, text: '学习' }, { id: 2, text: '休息' } ] } }) </script>
方法三直接使用Vue.ponent()
<div id="app"> <my></my> </div> <script src="https://cdn.jsdelivr./npm/vue/dist/vue.js"></script> <script type="text/javascript"> Vue.ponent('my',{ template : '<h3>这是使用 Vue.ponent 创建的组件</h3>' }) new Vue({ el: '#app' }) </script>
这样写会有一个问题在h3标签后出现另一个标签,就会出问题,
Vue.ponent('my',{ template : '<h3>这是使用 Vue.ponent 创建的组件</h3><h3>这是使用 Vue.ponent 创建的组件</h3>' })
- 原因组件template属性指向的模板内容,必须有且只能有唯一的一个根元素
- 解决方法: 用唯一的div作为父元素,将多个子元素包裹
方法四使用Vue.ponent()
在被控制的 #app 外面使用 template 元素,定义组建的HTML模板结构
<div id="app"> <my></my> </div> <template id="tem1"> <h1>这是 template 元素</h1> </template> <script src="https://cdn.jsdelivr./npm/vue/dist/vue.js"></script> <script type="text/javascript"> Vue.ponent('my', { template: '#tem1' }); new Vue({ el: '#app' }) </script>
方法五使用Vue.ponent() + 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./npm/vue/dist/vue.js"></script> <script type="text/javascript"> Vue.ponent('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组件的几种方法汇总的详细内容,更多关于html 创建调用vue组件的资料请关注狼蚁SEO其它相关文章!
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指