Vuejs——(8)Vuejs组件的定义
版权声明:出处http://blog.csdn.net/qq20004604
本篇资料来于官方文档:
http://cn.vuejs.org/guide/components.html
本文是在官方文档的基础上,更加细致的说明,代码更多更全。
简单来说,更适合新手阅读
(二十五)组件的定义
①组件的作用:
【1】扩展HTML元素,封装可重用的代码;
【2】组件是自定义元素,Vuejs的编译器可以为其添加特殊的功能;
【3】某些情况下,组件可以是原生HTML元素的形式,以is的方式扩展。
②写一个标准的组件:
分为以下几步:
【1】挂载组件的地方,需要是Vue实例所渲染的html元素,具体来说,比如上面的<div id=”app”></div>这样的html元素及他的子节点;
【2】定义一个组件,用
var 变量名 = Vue.extend({template:”这里是html的模板内容”})
这样的形式创建,例如:
- //定义一个组件
- var btn = Vue.extend({
- template: "<button>这是一个按钮</button>"
- })
【3】将定义的组件注册到Vue实例上,这会让指定标签,被组件的内容所替代。
如代码:
- //注册他到Vue实例上
- Vue.component("add-button", btn);
具体而言,每一个以下这样的标签(在Vue的根实例范围内的)
- <add-button></add-button>
会被
- <button>这是一个按钮</button>
所替代。
【4】以上方法是全局注册(每个Vue实例的add-button标签都会被我们定义的所替代);
解决办法是局部注册。
如代码:(这是是设置了template属性,也可以在没有这个属性的时候,在<div id=”app”></div>标签内放置<add-button></add-button>标签
- <div id="app">
- </div>
- <script>
- //定义一个组件
- var btn = Vue.extend({
- template: "<button>这是一个按钮</button>"
- })
- Vue.component("add-button", btn);
- //创建根实例,也就是说让Vue对这个根生效
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>"
- });
- </script>
③局部注册组件:
简单来说,只对这一个Vue实例生效,具体做法是,在注册那一步,跳过;
然后在声明Vue实例的时候,将添加到components这个属性中(他是一个对象,以KV形式放置)(注意,这个单词多一个s)
如代码:
- <div id="app">
- </div>
- <script>
- //定义一个组件
- var btn = Vue.extend({
- template: "<button>这是一个按钮</button>"
- })
- //创建根实例,也就是说让Vue对这个根生效
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": btn
- }
- });
- </script>
注:
根据官方教程,这种方法(指局部注册),也适用于其他资源,比如指令、过滤器和过渡。
④步骤简化:
【1】定义组件和注册组件结合起来一步完成:
- //定义一个组件
- Vue.component("add-button", {
- template: "<button>这是一个按钮</button>"
- });
【2】局部注册时,定义和注册一步完成:
- //创建根实例,也就是说让Vue对这个根生效
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮</button>"
- }
- }
- });
⑤data属性
直接给组件添加data属性是不可以的(无效);
原因在于,假如这么干,那么组件的data属性有可能是一个对象,而这个对象也有可能是外部传入的(例如先声明一个对象,然后这个对象作为data的值),可能导致这个组件的所有副本,都共享一个对象(那个外部传入的),这显然是不对的。
因此,data属性应该是一个函数,然后有一个返回值,这个返回值作为data属性的值。
且这个返回值应该是一个全新的对象(即深度复制的,避免多个组件共享一个对象);
如代码:
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮{{btn}}</button>",
- data: function () {
- return {btn: "123"};
- }
- }
- }
- });
另外,假如这样的话,btn的值是一样的(因为他们实际上还是共享了一个对象)
- <div id="app">
- </div>
- <div id="app2">
- </div>
- <script>
- var obj = {btn: "123"};
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮{{btn}}</button>",
- data: function () {
- return obj;
- }
- }
- }
- });
- obj.btn = "456";
- var vm2 = new Vue({
- el: '#app2',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮{{btn}}</button>",
- data: function () {
- return obj;
- }
- }
- }
- });
- </script>
注:
el属性用在Vue.extend()中时,也须是一个函数。
⑥is特性:
【1】按照官方教程,一些HTML元素对什么元素可以放在它之中是有限制的;
简单来说,如果我要在table标签内复用某个组件,这个组件展开后是tr标签,但是展开前不是,那么就无法正常运行(被放置在table标签内);
如代码(错误写法,会渲染错误):
- <div id="app">
- <table>
- <tr>
- <td>索引</td>
- <td>ID</td>
- <td>说明</td>
- </tr>
- <thetr v-for="i in items" v-bind:id="i" :index="$index"></thetr>
- </table>
- </div>
- <script>
- var vm = new Vue({
- el: '#app',
- data: {
- items: [1, 2, 3, 4]
- },
- methods: {
- toknowchildren: function () { //切换组件显示
- console.log(this.$children);
- }
- },
- components: {
- thetr: { //第一个子组件
- template: "<tr>" +
- "<td>{{index}}</td>" +
- "<td>{{id}}</td>" +
- "<td>这里是子组件</td>" +
- "</tr>",
- props: ['id', 'index']
- }
- }
- });
- </script>
渲染结果如下:
- <div id="app">
- <tr><td>0</td><td>1</td><td>这里是子组件</td></tr>
- <tr><td>1</td><td>2</td><td>这里是子组件</td></tr>
- <tr><td>2</td><td>3</td><td>这里是子组件</td></tr>
- <tr><td>3</td><td>4</td><td>这里是子组件</td></tr>
- <table>
- <tbody>
- <tr>
- <td>索引</td>
- <td>ID</td>
- <td>说明</td>
- </tr>
- </tbody>
- </table>
- </div>
可以明显发现,内容没有被放在table之中。
正确写法如下:
- <div id="app">
- <button @click="toknowchildren">点击让子组件显示</button>
- <table>
- <tr>
- <td>索引</td>
- <td>ID</td>
- <td>说明</td>
- </tr>
- <tr is="thetr" v-for="i in items" v-bind:id="i" :index="$index"></tr>
- </table>
- </div>
Vuejs——(8)Vuejs组件的定义的更多相关文章
- vuejs 单文件组件.vue 文件
vuejs 自定义了一种.vue文件,可以把html, css, js 写到一个文件中,从而实现了对一个组件的封装, 一个.vue 文件就是一个单独的组件.由于.vue文件是自定义的,浏览器不认识,所 ...
- Android:认识R类、findViewById方法查找组件、@string查找字符、@color查找颜色、@drawable查找图片、@dimen某个组件尺寸定义、项目引入资源国际化
导入 之前都是断断续续的看了一些于如何使用android开发的文章.资料等,到目前位置很多基础的东西都不清楚,于是去学习了别人的课程,才了认识了R类.findViewById方法查找组件.项目引入资源 ...
- Vue组件的定义、注册和调用
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>组 ...
- Vue.js 2.x:组件的定义和注册(详细的图文教程)
本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 前言 什么是组件 组件: 组件的出现,就是为了拆分Vue实例的代码量的, ...
- vue里在自定义的组件上定义的事件
事件分为原生事件和自定义事件. vue里在自定义的组件上定义的事件,都被认为是自定义事件,必须用$emit()来触发. 这也是子组件向父传值的原理. 如果想作为原生事件,需要在原生事件后面加上.nat ...
- Knockout.js组件系统的详解之(一) - 组件的定义和注册
(Knockout版本:3.4.1 ) KO的组件主要从以下四个部分进行详细介绍: 1.组件的定义和注册 2.组件绑定 3.使用自定义元素 4.自定义组件加载器(高级) 目录结构 1.通过" ...
- vue教程3-03 vue组件,定义全局、局部组件,配合模板,动态组件
vue教程3-03 vue组件,定义全局.局部组件,配合模板,动态组件 一.定义一个组件 定义一个组件: 1. 全局组件 var Aaa=Vue.extend({ template:'<h3&g ...
- Vue 数组封装和组件data定义为函数一些猜测
数组封装 var vm={ list:[0,1] } var push=vm.list.push;//把数组原来的方法存起来 vm.list.push=function(arg){//重新定义数组的 ...
- vue学习—组件的定义注册
组件的定义注册 效果: 方法一: <div id="box"> <v-header></v-header> <hr /> <b ...
随机推荐
- kettle实现多表同步
本样例实现源库的所有表到目标库的同步sqlserver=>mysql(目标表存在表结构则同步),总调度如下: 由于复制记录到结果保存了多个表名,存在多个值,在高级选择对每个输入行执行一次进行循环 ...
- 32. linux下oracle数据库定时备份
这里以oradatabak.sh(里面的内容要根据实际修改)脚本放在/u01/11g/datapump下为例: #1.添加脚本执行权限 chmod +x /u01/11g/datapump/orada ...
- 如何配置IIS使其支持APK文件的下载
在管理工具里打开Internet 信息服务(IIS)管理器.然后选择需要配置的网站. 右侧的界面中会显示该网站的所有功能配置,我们选择并点击进入“MIME类型” 在左侧的操作区选择点击“添加”MIME ...
- 面试小结之Elasticsearch篇(转)
最近面试一些公司,被问到的关于Elasticsearch和搜索引擎相关的问题,以及自己总结的回答. Elasticsearch是如何实现Master选举的? Elasticsearch的选主是ZenD ...
- 在chrome console添加jQuery支持
有时候想在chrome console使用jq,那么下面这段代码就可以完美解决问题了. var script = document.createElement('script');script.src ...
- jquery 找同胞系列siblings() ,next() ,nextAll(), nextUntil(), prev(), prevAll(), prevUntil()
注:expr是指可选的参数,包含用于匹配元素的选择器表达式. .siblings(expr) ---查找所有兄弟(包括哥哥和弟弟) .next(expr) ---查找紧挨着的弟弟 .nextAll(e ...
- spring boot+kafka整合
springboot版本是2.0.4 首先,在maven中引入spring-kafka的jar包 <dependency> <groupId>org.springframewo ...
- vs2015单步调试问题(附加进程)
如果页面有Codebehind的页属,那么前端通过ajax提交到后端代码,无法在后端代码中取到值. 这是一个vs属性标记,用于跟踪管理项目.如果后端代码的自定义指定(Inherits)的话,应该取掉 ...
- QUARTZ系列之一-基础概念(Scheduler/Job/JobDetail/Trigger)
摘抄自quartz官方文档: The key interfaces of the Quartz API are: Scheduler - the main API for interacting wi ...
- python 常用模块(一): os模块,序列化模块(json模块 pickle模块 )
1.os模块 2.序列化模块:(1)json模块 和 pickle模块 一.os模块 os.path.abspath: (1)把路径中不符合规范的/改成操作系统默认的格式 import os path ...