100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > vue中父子组件传值及slot使用剖析

vue中父子组件传值及slot使用剖析

时间:2021-03-30 12:19:20

相关推荐

vue中父子组件传值及slot使用剖析

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} })

效果图

具名插槽

如果想使用多个插槽,我们先看看效果:

This is header
This is footer

let child = {template : `

Main content

` } var vm = new Vue({el:#root,components:{ child} })

发现出现了多个header和footer,要解决这个问题就要用到具名插槽

我们修改代码如下:

This is header
This is footer

let child = {template : `

Main content

` } var vm = new Vue({el:#root,components:{ child} })

可以看到显示正常了

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。