首页 > 编程语言 >vue 组件间通信,ref属性,动态组件,插槽,计算属性,监听属性 node环境搭建

vue 组件间通信,ref属性,动态组件,插槽,计算属性,监听属性 node环境搭建

时间:2023-02-19 20:56:18浏览次数:40  
标签:---- age 间通信 var 组件 data 属性

昨日内容回顾

# 0 checkbox    v-model  只针对于input,做双向数据绑定
	-单选  :选中或不选中  选中就是true,不选中就是false
    -多选  :数组,选了多个,把选中的value值放到数组中

# 1 购物车案例
	-checkbox  多选
    -插值 可以放   函数()  把函数返回结果放在插值中
    -插值中的东西,只要变量发生变化,就会重新刷新  
    	getprice 使用了 checkbox的数组----》只要数组发生变化,getprice就会重新运算,刷新页面
        
        
        
# 2 全选全不选
	-全选的checkbox----》checkbox单选---》布尔类型----》每次变化都会触发handleCheckAll的执行
    	-只要是true,就把 this.checkGroup = this.goodList,
        -只要是false,把this.checkGroup = []
        
    -下面的每个checkbox----》checkbox多选---》数组类型----》每次变化触发handelCheckOne
    	-每次都要判断this.checkGroup长度和this.goodList长度是否一样,如果一样说明全选了,全选了就把checkAll 设置为true
        -否则,就是false
        
        
        
 #3 购物车带加减
	-加----》绑定点击事件,自增1 
    -减-----》函数判断,不能小于1 ,如果小于1 ,不让减了,做提示
	
    
    
 # 4 js  值类型和引用类型
	 python 可变和不可变
     python一切皆对象----》对象就绑定了方法  
        
     深浅拷贝
    
    
    
# 5 v-model进阶   修饰v-model
		-lazy
    	-number
        -trim 
        
        
 # 6 与后端交互
	-axios 与后端交互
    -axios.get('地址').then(res=>{
        res 对象,  res.data  响应体的数据
        
    })
    
# 7 小电影案例
	
    
    
# 8 生命周期钩子  8个 
	-created 
    -beforeDestroy
    
# 9 如何实现服务端主动推送消息效果[在线聊天室]
	-http  轮询  长轮询  websocket-不是所有浏览器都兼容
    
    
# 10 组件   组件化开发
	-全局组件
    	Vue.component('名字',{template,data(){return {}},methods,生命周期})
        
    -局部组件(只能用在当前组件中)   以后咱们用局部组件用的多
    	components: {
            foo:{}
        }	

image-20230217090755542

今日内容

  • 组件其他

  • 组件间通信之父传子

  • 组件间通信之子传父

  • ref属性

  • 动态组件

  • 插槽

  • 计算属性

  • 监听属性

  • node环境搭建

1 组件其他

# 根组件 和 组件 一些问题
	-new Vew()---->管理div----》根组件
    -自己再定义的全局,局部是组件
   	-组件有自己的html,css,js ---》数据,事件,。。。。。
    -在组件中,this 代指当前组件
    -父子组件的data是无法共享的
    -data是1个函数,需要有返回值(return)

2 组件间通信之父传子

# 组件间数据不共享----》需要进行数据传递

# 父传子:使用自定义属性方式

自定义属性

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div class="app">
        <h1>父子通信之父传子,通过自定义属性---->不能用驼峰,不要跟子组件变量冲突</h1>

        <h2>字符串的age--->age='age'</h2>
        <child age="age"></child>

        <h2>数字19---->:age="19"</h2>
        <child :age="19"></child>

        <h2>字符串19---->age="19"</h2>
        <child age="19"></child>

        <h2>变量数字19---->:age="age"</h2>
        <child :age="age"></child>
        


    </div>
</body>

<script>
    // 父中有age,子child 只有name,没有age,现在把父中的age传到child中,显示
    var child = {
        template:`
        <div>
            <button>后退</button>
            首页--->名字:{{myname}}--->年龄:{{age}}
            <button>前进</button>
        </div>`,
        data(){
            return{
                myname:'ikun'
            }
        },
        props:['age'], //可以用数组
    }
    var vm = new Vue({
        el:'.app',
        data:{
            age:19
        },
        components:{
            child
        }
    })
</script>
</html>

image-20230217214913845

属性验证

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div class="app">

        <h1>属性验证--->传入的必须是xx类型</h1>

        <h2>字符串的age--->age='age'</h2>
        <child age="age"></child>

        <h2>数字19---->:age="19"</h2>
        <child :age="19"></child>

        <h2>字符串19---->age="19"</h2>
        <child age="19"></child>

        <h2>变量数字19---->:age="age"</h2>
        <child :age="age"></child>



    </div>
</body>

<script>
    // 父中有age,子child 只有name,没有age,现在把父中的age传到child中,显示
    var child = {
        template:`
        <div>
            <button>后退</button>
            首页--->名字:{{myname}}--->年龄:{{age}}
            <button>前进</button>
        </div>`,
        data(){
            return{
                myname:'ikun'
            }
        },
        // props:['age'],
        props:{age: Number} // 也可以用对象 可以指定属性 这里指定age是数字
    }
    var vm = new Vue({
        el:'.app',
        data:{
            age:19
        },
        components:{
            child
        }
    })
</script>
</html>

image-20230217215955648

image-20230217220048868

3 组件间通信之子传父

# 通过自定义事件

image-20230217103331749

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    
<div class="app">
    <p>子组件传递过来的数据: {{mytext}}</p>
    <hr>
    <child @myevent="handleEvent"></child>
    <hr>
</div>

</body>
<script>
    var child = {
        template: `
          <div>
          <input type="text" v-model="mytext">
          <button @click="handleSend">点我传递</button>
          </div>`,
        data() {
            return {
                mytext: ''
            }
        },
        methods: {
            handleSend() {
                // alert(this.mytext)
                // 子组件中,触发自定义事件的执行,会执行父组件自定义事件绑定的函数,有几个参数,就传几个参数
                this.$emit('myevent', this.mytext)
            }
        }

    }

    var vm = new Vue({
        el: '.app',
        data: {
            mytext: ''
        },
        methods: {
            handleEvent(mytext) {
                this.mytext = mytext

            }
        },
        components: {
            child
        }

    })
</script>
</html>

image-20230219161111406

4 ref属性

# 自定义属性和自定义事件  可以实现父子传值

# ref属性  可以更方便的实现父子通信


# ref属性放在普通标签上  <input type="text" ref="myinput">
	-通过this.$refs.myinput  拿到的是原生dom对象,通过原生dom修改 标签


#ref属性放在组件上   <child ref="mychild"></child>
	-通过this.$refs.mychild  拿到的是组件对象,既然拿到了组件对象,组件对象中的 变量,方法,都能直接通过 . 的方式调用
    -因此不需要关注是子传父,还是父传子,直接通过组件对象,使用即可
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
    <p ref="myp">嘿嘿</p>

    <input type="text" ref="myinput">

</div>
</body>
<script>
    let vm = new Vue({
        el: '#app',
        data: {
            age: 18
        },

    })
</script>
</html>

image-20230219172436512

image-20230219172519215

image-20230219172731923

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
    <p ref="myp">嘿嘿</p>

    <input type="text" ref="myinput">

    我是父组件 {{age}}
    <br>
    <br>
    <br>
    <child ref="mychild"></child>
    <button @click="headlClick(1)"> 传递 子传父</button>
    <button @click="headlClick(2)"> 传递 父传子</button>
</div>
</body>
<script>
    let foo = {
        template: `
          <div>
          我是子组件 {{ age }}
          </div>
        `, data() {
            return {age: 288}
        },

    }


    let vm = new Vue({
        el: '#app',
        data: {
            age: 18
        },
        components: {
            child: foo
        },
        methods: {
            headlClick(args) {
                if (args === 1) {
                    this.age = this.$refs.mychild.age
                } else {
                    this.$refs.mychild.age = this.age
                }
            }
        }

    })
</script>
</html>

image-20230219173031621

image-20230219173047124

image-20230219173225697

ref 属性放在组件上,拿到的是组件对象,就可以使用组件对象的属性和方法

重点: 以后就不需要关注是子传父还是父传子了,直接通过对象取值即可,而且可以主动调用子组件中的函数

5 动态组件

5.1 不使用动态组件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
    <span @click="handleClick('home')">首页</span>| <span @click="handleClick('order')">订单</span> | <span
        @click="handleClick('goods')">商品</span>
    <home v-if="chooseType=='home'"></home>
    <order v-else-if="chooseType=='order'"></order>
    <goods v-else></goods>
</div>
</body>
<script>

    var home = {
        template: `
          <div>
          <h1>home页面</h1>
          </div>`,

    }
    var order = {
        template: `
          <div>
          <h1>order页面</h1>
          </div>`,

    }
    var goods = {
        template: `
          <div>
          <h1>商品页面</h1>
          </div>`,

    }

    var vm = new Vue({
        el: '.app',
        data: {
            chooseType: 'home'
        },
        methods: {
            handleClick(type) {
                this.chooseType = type
            }
        },
        components: {
            home, order, goods
        }


    })
</script>
</html>

但是这种 v-if如果子组件多的话写的太麻烦了

5.2 动态组件 component标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
    <span @click="handleClick('home')">首页</span>| <span @click="handleClick('order')">订单</span> | <span
        @click="handleClick('goods')">商品</span>

    <component :is="who"></component>

</div>

</body>
<script>

    var home = {
        template: `
          <div>
          <h1>home页面</h1>
          </div>`,

    }
    var order = {
        template: `
          <div>
          <h1>order页面</h1>
          </div>`,

    }
    var goods = {
        template: `
          <div>
          <h1>商品页面</h1>
          </div>`,

    }

    var vm = new Vue({
        el: '.app',
        data: {
            who: 'home'
        },
        methods: {
            handleClick(type) {
                this.who = type
            }
        },
        components: {
            home,
            order, goods
        }

    })
</script>
</html>

image-20230219194124528

5.2 keep-alive保持组件不销毁

现在出现了一个问题,如果一个页面有数据,切换再切换回来数据就丢失了

image-20230219195214912

image-20230219195227308

这需要用 keep-alive标签包一下

image-20230219195422106

image-20230219195431098

这样数据就不会丢失了

6 插槽

# 一般情况下,编写完1个组件之后,组件的内容都是写死的,需要加数据 只能去组件中修改,扩展性很差
# 然后就出现了插槽这个概念,只需在组件中添加<slot></slot>,就可以在body的组件标签中添加内容

6.1 匿名插槽

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div class="app">

    <hr>
    <home>
        <div>
            <img src="./1.png" alt="" style="width: 300px;height: 150px">

        </div>
    </home>
    <hr>

</div>
</body>
<script>
    var home = {
        template: `
          <div>
          <h1>home页面</h1>
            <slot></slot>
            <h1>结束了</h1>
          </div>`,

    }
    var vm = new Vue({
        el: '.app',
        data: {},
        components: {
            home,
        }
    })
</script>
</html>

image-20230219200323764

image-20230219200504157

image-20230219200556136

6.2 具名插槽

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div class="app">

    <hr>
    <home>
        <div slot="a">
            <img src="./1.png" alt="" style="width: 300px;height: 150px">
        </div>

        <div slot="b">
            <p>大美女</p>
        </div>
    </home>
    <hr>

</div>

</body>
<script>

    var home = {
        template: `
          <div>
          <h1>home页面</h1>
            <slot name="a"></slot>
            <h1>结束了</h1>
            <slot name="b"></slot>
          </div>`,

    }
    var vm = new Vue({
        el: '.app',
        data: {},
        components: {
            home,
        }


    })
</script>
</html>

image-20230219201133307

image-20230219201143353

7 计算属性

# 计算属性只有使用的变量发生变化时,才重新运算
# 计算属性就像Python中的property,可以把方法/函数伪装成属性

7.1 计算属性基本使用

计算属性只有使用的变量发生变化的时,才重新运算

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div class="app">

    <!--    <h1>input输入单词,首字母转成大写展示</h1>-->
    <!--    <input type="text" v-model="mytext">&#45;&#45;&ndash;&gt;{{mytext.slice(0, 1).toUpperCase() + mytext.slice(1)}}-->


    <h1>input输入单词,首字母转成大写展示---函数方式---》只要页面刷新,无论跟它有没有关,都会重新运算</h1>
    <!--    <input type="text" v-model="mytext">&#45;&#45;&ndash;&gt;{{getUpper()}}-->
    <input type="text" v-model="mytext">---->{{newText}}
    <br>
    <input type="text" v-model="age">--->{{age}}
</div>

</body>
<script>

    var vm = new Vue({
        el: '.app',
        data: {
            mytext: '',
            age: 10
        },
        methods: {
            getUpper() {
                console.log('函数---我执行了')
                return this.mytext.slice(0, 1).toUpperCase() + this.mytext.slice(1)
            }
        },
        // 计算属性---->computed 里面写方法,以后,方法当属性用 ,一定要有return值
        computed: {
            newText() {
                console.log('计算属性---我执行了')
                return this.mytext.slice(0, 1).toUpperCase() + this.mytext.slice(1)
            }
        }
    })
</script>
</html>
计算属性---->computed 里面写方法,以后,方法当属性用 ,一定要有return值

image-20230219202305621

7.2 通过计算属性重写过滤案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div>
    <div class="app">
        <h1>过滤案例</h1>
        <p>请输入要搜索的内容:<input type="text" v-model="myText"></p>
        <ul>
            <li v-for="item in newDateList">{{item}}</li>
        </ul>

    </div>

</div>
</body>
<script>
    var vm = new Vue({
        el: '.app',
        data: {
            myText: '',
            dataList: ['a', 'at', 'atom', 'be', 'beyond', 'cs', 'csrf'],
        },
        computed: {
            newDateList() {
                return this.dataList.filter(
                    item => item.indexOf(this.myText) >= 0
                )
            }
        }
    })
</script>
</html>

8 监听属性

在data 中定义了一些变量,只要变量发生变化,我们就执行一个函数

watch:{
    属性名(){
        
    }
} 
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div>
    <div class="app">
        <button @click="course_type=1">Python</button> <button @click="course_type=2">Linux</button>
        <div>
            假设有很多课程,点击上面的标签可以完成过滤
        </div>

    </div>

</div>
</body>
<script>
    var vm = new Vue({
        el: '.app',
        data: {
            course_type: ''
        },
        watch: {
            course_type(item) {
                console.log(item)
                console.log('我变化了')
            }
        }

    })
</script>
</html>

image-20230219203608023

image-20230219203707437

9 node环境搭建

# Vue-CLI 项目搭建
	-vue 脚手架  可以创建vue项目
    
    
# vue脚手架必须要按照 node js   解释型语言
	-node js是一门后端语言
    -JavaScript只能运行在浏览器中,因为浏览器中有他的解释器环境
    -基于谷歌浏览器的v8引擎(js解释器),使它能够运行在操作系统上
    	-文件操作
        -网络操作
        -数据库操作  模块
        
        
        
   -nodejs 解释器环境
	-http://nodejs.cn/  下载对应平台的nodejs解释器
    -一路下一步安装
    -安装完成会有两个可执行问题
    	python    node 
        pip       npm
        
    -打开cmd
     node  进入到了node环境
     npm install 装模块

标签:----,age,间通信,var,组件,data,属性
From: https://www.cnblogs.com/super-xz/p/17135554.html

相关文章

  • themyleaf th:foreach 遍历时第二个参数 stat 属性说明
    stat是状态变量,有如下属性:index遍历顺序从零下标开始计数count遍历顺序从一下标开始计数size遍历的集合长度current当前项even/odd判断奇偶first判断是否......
  • 【JavaScript】18_面向对象,类与属性
    1、面向对象面向对象编程(OOP)程序是干嘛的?程序就是对现实世界的抽象(照片就是对人的抽象)对象是干嘛的?一个事物抽象到程序中后就变成了对象在程序的世界中,一切皆对象面向对象......
  • ThreadLocal父子间通信的四种解决方案
    ThreadLocal父子间通信的四种解决方案ThreadLocal是存储在线程栈帧中的一块数据存储区域,其可以做到线程与线程之间的读写隔离。但是在我们的日常场景中,经常会出现父线程......
  • vue组件间通信,ref属性,动态组件,插槽,计算属性,监听属性
    内容回顾checkboxv-model只针对于input,做双向数据绑定单选:选中或不选中选中就是true不选择就是false多选:数组,选了多个,把选中的value值放到数组中购物车案例check......
  • 大数据组件之Apache Oozie
    1、Oozie介绍官网首页介绍:​​​​http://oozie.apache.org​​​1.1Oozie是一个管理ApacheHadoop作业的工作流调度系统。1.2Oozie的workflowjobs是由actions组成......
  • 历史表迁移组件设计
    背景:通过sql语句和配置表的手段进行历史表的数据迁移过程。指标:扩展性,高性能核心类/接口说明:HistoryProductDirector:指挥者,负责安排已有模块的顺序,然后通知Builder开始建......
  • etcd学习笔记-组件架构
    etcd项目结构其中核心模块etcdserver,lease,mvcc,raft整体架构客户端层包括clientv3和etcdctl等客户端,用户通过命令行或者客户端通过restfulapi降低了etcd客户端的使用复杂......
  • 购物车案例&v-model进阶&与后端交互&vue生命周期&vue组件
    目录购物车案例&v-model进阶&与后端交互&vue生命周期&vue组件今日内容概要今日内容详细1购物车案例1.1基本购物车1.2带全选全不选1.3带加减2v-model进阶3与后端交互3......
  • 【Kotlin】Kotlin 与 Java 互操作 ① ( 变量可空性 | Kotlin 类型映射 | Kotlin 访问
    文章目录​​一、Kotlin变量可空性​​​​1、Java与Kotlin空值处理区别​​​​2、Java函数返回非空值和控制​​​​3、Kotlin函数调用Java函数​​​​4、平台类......
  • __name__属性 和 标签 Tag
    __name__属性(1)__name__是属于python中的内置属性,代表对应程序名称。(2)__name在当前执行文件中使用时,他的值为_main__在被调用的模块中时,其值为被调用文件所在的......