web前端|js教程
slot,剖析,使用
web前端-js教程一.父子组件传值
c3扫雷源码,vscode符号跳转,ubuntu有线宽带,tomcat意外终止,SQLite的目的是,jquery下载插件,企业常用的前端框架,python登录爬虫系列,sublime php,seo关键词指数,贵金属企业网站模板,完整网页聊天源码,杰奇cms模板下载,jquery 分段加载页面,学生管理系统sql源代码,程序代码入门lzw
{{total}}
html浪漫源码,vscode调试多个c,ubuntu生成源,tomcat怎么设定路由,安卓版sqlite3,网络爬虫抓取消费者信息工具,php数组转换js数组,淮安seo推广哪家便宜,优惠券网站源码,目录 html 模板lzw
卡乐购官网源码,vim命令打开vscode,ubuntu转lmv,tomcat闪退详解,爬虫sparkRDD分析,php sql注入方法,遂宁seo网络推广公司排名,拓网手机触屏版网站管理系统,软件安装说明书模板lzw
//父组件向子组件传值用 props ,加:号后传递的为js表达式,示例中则为数字,不加:号代表的是字符串 var counter = { //局部注册props:[count],data:function(){//在子组件中定义数据,data不能是对象,必须是一个函数。 return { number:this.count }},template:
{{number}}
,methods:{handleClick2:function(){ this.number ++; //this.count++; 父组件可以传值给子组件,但子组件不可以修改父组件属性,这里这么写会报错。 this.$emit("numberchange",this.number);//子组件向父组件传递事件,值} } } var validateContent = { props:{//content:[Number,String] //组件参数校验,可以多选content:{//组件参数校验 type:String, required:true, default:"default value", validator:function(value){return value.length > 5 }}},template:
{{content}}
, } var vm = new Vue({el:#root,data:{ total:0},methods:{ handleChange:function(number){ console.log(number) // this.total +=1;}},components:{ counter, //局部注册要在根节点注册组件 validateContent} })
二.父组件向子组件传递DOM
先看一个示例
Qin
let child = {template :`
hello world
` } var vm = new Vue({el:#root,components:{ child} })
打开查看器查看一下
发现Qin不见了
Qin
1
查看官方文档 , /v2/guide/components-slots.html
我们得出结论:如果 child 没有包含一个 元素,则任何传入它的内容都会被抛弃
我们加入插槽
Qin
let child = {template :`
hello world
` } var vm = new Vue({el:#root,components:{ child} })
发现Qin能正常显示,且slot将会被替换为解析后的片段
Qin
当父组件不向子组件传值的时候,slot还可以作为父组件默认值出现
let child = {template :`
hello world
default value ` } var vm = new Vue({el:#root,components:{ child} })
效果图
具名插槽
如果想使用多个插槽,我们先看看效果:
let child = {template : `
Main content
` } var vm = new Vue({el:#root,components:{ child} })
发现出现了多个header和footer,要解决这个问题就要用到具名插槽
我们修改代码如下:
let child = {template : `
Main content
` } var vm = new Vue({el:#root,components:{ child} })
可以看到显示正常了