欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

html中创建并调用vue组件的几种方法汇总

程序员文章站 2022-04-09 16:58:29
作者:echoyya出处:最近在写项目的时候,总是遇到在html中使用vue.js的情况,且页面逻辑较多,之前的项目经验都是使用脚手架等已有的项目架构,使用.vue文件完成组价注册,及组件之间的调用,...

作者:echoyya
出处:

最近在写项目的时候,总是遇到在html中使用vue.js的情况,且页面逻辑较多,之前的项目经验都是使用脚手架等已有的项目架构,使用.vue文件完成组价注册,及组件之间的调用,还没有过在html中创建组件的经验,所以借此机会学习总结一下。

方法一:vue.extend( options )

  • 用法:使用基础 vue 构造器,创建一个“子类”。参数是一个包含组件选项的对象。data 选项是特例,需要注意 - 在 vue.extend() 中它必须是函数
  • extend 创建的是 vue 构造器,而不是我们平时常写的组件实例,所以不可以通过 new vue({ components: testextend }) 来直接使用,需要通过 new profile().$mount('selector选择器') 来挂载到指定的元素上。
  • vue.extend + vm.$mount 组合

方法二:vue.component( id, [definition] ) + vue.extend( options )

用法:vue.component()注册或获取全局组件。注册还会自动使用给定的 id 设置组件的名称

方法三:直接使用vue.component()

但是这样写会有一个问题:在h3标签后出现另一个标签,就会出问题,

html中创建并调用vue组件的几种方法汇总

  • 原因:组件template属性指向的模板内容,必须有且只能有唯一的一个根元素
  • 解决方法: 用唯一的div作为父元素,将多个子元素包裹

方法四:使用vue.component()

在被控制的 #app 外面使用 template 元素,定义组建的html模板结构

方法五:使用vue.component() + is

补充说明一下is属性:

有些 html 元素,诸如 ul、ol、table 和 select,对于可以出现在其内部元素是有严格限制的。而有些元素,诸如 li、tr 和 option,只能出现在特定的元素内部。这会导致我们使用这些有约束条件的元素时遇到一些问题。例如

这个自定义组件 会被作为无效的内容提升到外部,并导致最终渲染结果出错。幸好这个特殊的 is attribute 给了我们一个变通的办法:

以上就是html中创建并调用vue组件的几种方法汇总的详细内容,更多关于html 创建调用vue组件的资料请关注其它相关文章!

相关标签: html vue 组件