首页 > 其他分享 >Vue——计算属性、监听属性、Vue生命周期、组件介绍和使用、组件间通信、ref属性

Vue——计算属性、监听属性、Vue生命周期、组件介绍和使用、组件间通信、ref属性

时间:2023-06-06 19:49:13浏览次数:50  
标签:el Vue console log 组件 data 属性

计算属性

// 1 计算属性是基于他们的依赖变量进行缓存的
// 2 计算属性只有在它的相关依赖变量发生改变时才会重新求值,否则不会变(函数只要页面变化,就会重新运算)
// 3 计算属性就像python中的property装饰器,可以把方法/函数伪装成属性
// 4 计算属性,必须有返回值

<body>
<div id="app">
    <h1>实现输入input中后名字首字母大写</h1>
    <input type="text" v-model="username">------{{getUpperCase()}}
    <hr>
    <h1>通过计算属性实现--->当属性用</h1>
    <input type="text" v-model="username1">------{{getName}}
</div>
</body>
<script>
    let vm = new Vue({
        el: '#app',
        data: {
            username: '',
            age: '',
            username1: ''
        },
        methods: {
            getUpperCase() {
                console.log('函数我执行了')
                return this.username.substring(0, 1).toUpperCase() + this.username.substring(1)
            },
        },
        computed: {
            getName() {
                console.log('计算属性执行了')
                return this.username1.substring(0, 1).toUpperCase() + this.username1.substring(1)
            }
        }
    })
</script>

重写过滤案例

<div id="app">
    <input type="text" v-model="search">
    <hr>
    <ul>
        <li v-for="item in newdataList">{{item}}</li>
    </ul>
</div>
</body>
<script>
    let vm = new Vue({
        el:'#app',
        data:{
            search:'',
            dataList: ['a', 'at', 'atom', 'attoo', 'be', 'beyond', 'cs', 'csrf'],
        },
        computed:{
            newdataList(){
                return this.dataList.filter(item=>item.indexOf(this.search)>=0)
            }
        }
    })
</script>

监听属性

// 属性如果发送变化 就会执行某个函数

<body>
<div id="app">
    <h1>监听属性</h1>
    <input type="text" v-model="username">-------{{username}}
</div>
</body>
<script>
    let vm = new Vue({
        el: '#app',
        data: {
            username: '',
        },
        watch: {
            username(newValue, oldValue) {
                console.log('老值', oldValue)
                console.log('新值', newValue)
            }
        }
    })
</script>

Vue生命周期

// new Vue()--->创建出来--->页面关闭--->被销毁掉--->整个整个过程经历了一个周期--->vue帮我们提供了一些钩子函数(写了就会执行,不写就不会执行),到某个阶段,就会触发某个函数的执行

// 8个生命周期钩子函数
	beforeCreate		创建Vue实例之前调用
	created				创建Vue实例成功后调用
	beforeMount			渲染DOM之前调用
	mounted				渲染DOM之后调用
	beforeUpdate		重新渲染之前调用(数据更新等操作时,控制DOM重新渲染)
	update				重新渲染完成之后调用
	beforeDestroy		销毁之前调用
	destroyed			销毁之后调用

// vue实例有生命周期,每个组件也有这8个生命周期

// 8个生命周期钩子,什么情况会用户到
	created:用的最多,变量初始化完成了(data中得到数据),在这里我们发送ajax请求
	beforeDestroy:组件销毁之前会执行
		组件创建,就执行一个定时任务(每隔1s,打印一个helloworld)
		组件销毁,定时任务要销毁,如果定时任务不消化,会一直执行

<body>
<div id="app">
    <h1>生命周期钩子</h1>
    <input type="text" v-model="username">---{{username}}

    <h1>使用组件</h1>
    <button @click="handleShow">显示/隐藏组件</button>
    <hr>
    <child v-if="show"></child>
    <hr>
</div>
</body>
<script>
    // 定义一个全局组件 在组件中data必须是函数且返回对象
    Vue.component('child', {
        template: `
          <div>
          <button @click="back">后退</button>
          {{ name }}
          <button @click="go">前进</button>
          </div>`,
        data() {
            return {
                name: '首页',
                t: null,
            }
        },
        methods: {
            back() {
                alert('后退')
            },
            go() {
                alert('前进')
            },
        },
        beforeCreate() {
            console.log('beforeCreate')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
        },
        created() {
            console.log('created')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)

            // 启动一个定时器
            this.t = setInterval(() => {
                console.log('hello world')
            }, 1000)
        },
        beforeMount() {
            console.log('beforeMount')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
        },
        mounted() {
            console.log('mounted')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
        },
        beforeUpdate() {
            console.log('beforeUpdate')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
        },
        updated() {
            console.log('updated')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
        },
        beforeDestroy() {
            console.log('beforeDestroy')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
            // 销毁定时器
            clearInterval(this.t)
            this.t = null
        },
        destroyed() {
            console.log('destroyed')
            console.log('当前el状态:', this.$el)
            console.log('当前data状态:', this.$data)
            console.log('当前name状态:', this.name)
        },
    })

    let vm = new Vue({
        el: '#app',
        data: {
            username: '',
            show: false,
        },
        methods: {
            handleShow() {
                this.show = !this.show
            }
        },
        // beforeCreate() {
        //     console.log('beforeCreate')
        // },
        // created() {
        //     console.log('created')
        // },
        // beforeMount() {
        //     console.log('beforeMount')
        // },
        // mounted() {
        //     console.log('mounted')
        // },
        // beforeUpdate() {
        //     console.log('beforeUpdate')
        // },
        // updated() {
        //     console.log('updated')
        // },
        // beforeDestroy() {
        //     console.log('beforeDestroy')
        // },
        // destroyed() {
        //     console.log('destroyed')
        // },
    })
</script>

image

组件介绍和使用

// 组件就是:扩展html元素,封装可重用的代码,目的是复用
例如:有一个轮播图,可以在很多页面中使用,一个轮播有js,css,html
组件把js,css,html放到一起,有逻辑,有样式,有html

// 组件的分类
	全局组件:可以放在根中,可以在所有组件中使用
	局部组件:只能在当前组件中使用

// 1.全局组件是使用Vue.component定义的,可以在全局任意组件中使用
// 2.局部组件是定义在某个组件内的:components,只能用在当前组件中
// 3.组件可以嵌套定义和使用

定义全局组件

<body>
<div id="app">
    <h1>组件的使用</h1>
    <hr>
    <child></child>
    <hr>

    <h1>第二个位置使用</h1>
    <child></child>
</div>
</body>
<script>
    //1  定义一个全局组件,vue2中,组件必须在一个标签中
    Vue.component('child', {
        template: `
          <div>
          <button @click="back">后退</button>
          {{ title }}
          <button @click="go">前进</button>
          </div>`,
        data() {
            return {
                title: '我是首页'
            }
        },
        methods: {
            back() {
                alert('后退')
            },
            go() {
                alert('前进')
            }
        },
    })

    let vm = new Vue({
        el: '#app',
    })
</script>

定义局部组件

<body>
<div id="app">
    <h1>组件的使用</h1>
    <hr>
    <child></child>
    <hr>
</div>
</body>
<script>
    let child = {
        template: `
          <div>
          <h1>我是局部组件</h1>
          <img :src="url" alt="" height="400px">
          </div>`,
        data() {
            return {
                url: 'https://img2.baidu.com/it/u=254883480,2339132336&fm=253&fmt=auto&app=138&f=JPEG?w=400&h=400'
            }
        },
    }

    let vm = new Vue({
        el: '#app',
        data: {},
        // 局部组件是定义在某个组件内,可以定义多个,只能在它父组件中使用,不能到别的地方使用
        components: {
            child
        }
    })
</script>

全局组件和局部组件的混合使用

// 全局组件可以全局任意位置使用 包括在局部组件中使用全局组件
// 局部组件只能在它的父组件中使用 也就是说在谁下面定义的局部组件就只能在谁里面使用 其他地方不能使用

<body>
<div id="app">
    <h1>组件的使用</h1>
    <p>全局组件</p>
    <hr>
    <child></child>
    <hr>
    <div style="height: 100px"></div>
    <p>局部组件</p>
    <hr>
    <local></local>
    <hr>
</div>
</body>
<script>
    // 全局组件
    Vue.component('child', {
        template: `
          <div>
          <button @click="back">后退</button>
          {{ title }}
          <button @click="go">前进</button>
          </div>`,
        data() {
            return {
                title: '我是首页'
            }
        },
        methods: {
            back() {
                alert('后退了')
            },
            go() {
                alert('前进了')
            }
        }
    })

    // 局部组件 可以在局部组件中使用全局组件
    let local = {
        template: `
          <div>
          <img :src="url" alt="" height="400px">
          <child></child>
          </div>`,
        data() {
            return {
                url: 'https://img2.baidu.com/it/u=254883480,2339132336&fm=253&fmt=auto&app=138&f=JPEG?w=400&h=400'
            }
        },
    }

    let vm = new Vue({
        el: '#app',
        data: {},
        components: {
            local
        },
    })
</script>

组件间通信

// 组件嵌套
	父组件把数据传递给子组件
		自定义属性
		1 在子组件中自定义属性,使用属性指令绑定父组件的变量
		2 在子组件中,使用props接收 ['属性名1','属性名2']
		3 在子组件中,使用属性名即可
	
	子组件把数据传递给父组件
		自定义事件
		1 父组件中自定义事件:<lqz @myevent="handelEvent"></lqz>
		2 子组件中只要执行 this.$emit('myevent'),就会触发自定义事件对应的函数

组件间通信之父传子

<body>
<div id="app">
    <h1>组件间通信</h1>
    <hr>
    <local :url="url" :myshow="true" :mytitle="title"></local>
    <hr>
</div>
</body>
<script>
    // 局部组件
    let local = {
        template: `
          <div>
          <h1>我是局部组件</h1>
          <h2>{{mytitle}}</h2>
          <h2>{{title}}</h2>
          <img :src="url" alt="" height="400px">
          <button @click="handleCheck">点我看myshow类型</button>
          </div>`,
        data() {
            return {
                title: '我是子组件中的首页'
            }
        },
        methods:{
            handleCheck(){
                console.log(this.myshow)
                console.log(typeof this.myshow)
            }
        },
        props:['url','myshow','mytitle'],
    }

    // 跟组件
    let vm = new Vue({
        el: '#app',
        data: {
            url: 'https://img2.baidu.com/it/u=254883480,2339132336&fm=253&fmt=auto&app=138&f=JPEG?w=400&h=400',
            title:'我是父组件中的首页'
        },
        components: {
            local,
        },
    })
</script>

image

组件间通信之子传父

<body>
<div id="app">
    <h1>组件间通信之子传父</h1>
    接受到的子组件输入的内容是:{{username}}
    <hr>
    <local @myevent="handleEvent"></local>
    <hr>
</div>
</body>
<script>
    // 局部组件
    let local = {
        template: `
          <div>
          <h1>我是局部组件</h1>
          <img :src="url" alt="" height="400px">
          <br>
          <input type="text" v-model="username">
          <button @click="handleSend">传递到父组件</button>
          </div>`,
        data() {
            return {
                url: 'https://img2.baidu.com/it/u=254883480,2339132336&fm=253&fmt=auto&app=138&f=JPEG?w=400&h=400',
                username: ''
            }
        },
        methods: {
            handleSend() {
                // 传递到父组件
                this.$emit('myevent', this.username)
            }
        }
    }

    // 根组件
    let vm = new Vue({
        el: '#app',
        data: {
            username: '',
        },
        methods: {
            handleEvent(username) {
                this.username = username
            }
        },
        // 局部组件
        components: {
            local
        },
    })
</script>

image

ref属性

// ref属性,vue提供的,写在标签上
	可以写在普通标签:在vue中使用 this.$refs.名字 拿到DOM对象,可以原生操作
	可以写在组件上:在vue中使用 this.=$refs.名字 拿到[组件]对象、属性、方法直接使用

<body>
<div id="app">
    <h1>ref属性放在普通标签上</h1>
    <input type="text" v-model="username" ref="myinput">
    <br>
    <img src="https://img2.baidu.com/it/u=254883480,2339132336&fm=253&fmt=auto&app=138&f=JPEG?w=400&h=400" alt=""
         height="300px" ref="myimg">

    <h1>ref放在组件上</h1>
    <hr>
    <local ref="mylocal"></local>
    <hr>

    <button @click="handleClick">点我执行函数</button>
    <br>
    {{username}}
</div>
</body>
<script>
    let vm = new Vue({
        el: '#app',
        data: {
            username: '',
        },
        methods: {
            handleClick() {
                console.log(this.$refs)
                // 通过key,取到标签,拿到原生dom,通过dom操作,控制标签
                // this.$refs.myinput.value = 'XxMa'
                // this.$refs.myimg.src = 'https://img2.baidu.com/it/u=3088799631,1458572411&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500'

                // 放在组件上--->现在在父组件中,能拿到子组件对象,对象中的属性和方法直接用即可
                console.log(this.$refs.mylocal)
                // this.$refs.mylocal.title = '我的首页'
                // this.username = this.$refs.mylocal.title
                // this.$refs.mylocal.back()
            }
        },
        components: {
            local: {
                template: `
                  <div>
                  <button @click="back">后退</button>
                  {{ title }}
                  <button @click="go">前进</button>
                  </div>`,
                data() {
                    return {
                        title: '首页'
                    }
                },
                methods: {
                    back() {
                        alert('后退了')
                    },
                    go() {
                        alert('前进了')
                    }
                }
            }
        }
    })
</script>

标签:el,Vue,console,log,组件,data,属性
From: https://www.cnblogs.com/XxMa/p/17461511.html

相关文章

  • 特殊文件:Properties属性文件
             ......
  • 爬取网站的背景是获取《王者荣耀》游戏中各个英雄的详细属性数据
    一,选题背景 此次爬取网站的背景是获取《王者荣耀》游戏中各个英雄的详细属性数据,以便进行游戏分析和比较。《王者荣耀》是一款非常流行的多人在线战斗竞技游戏,拥有大量的英雄角色,每个英雄都有其独特的属性和技能。游戏玩家需要通过了解每个英雄的属性和技能,才能更好地制定游戏......
  • uniapp使用uview组件的indexList写选择城市
    <template><viewclass=""><viewclass="top"><viewclass="search-boxmt10flexalcenter"><viewclass="search-input"><u-search:showAction=&q......
  • vue之生命周期钩子
    目录一、生命周期图1.官方原图2.理解的图二、生命周期8个声明周期钩子,什么情况会用到组件销毁-给组件写一个定时器一、生命周期图1.官方原图2.理解的图二、生命周期newVue()---->创建出来---》页面关闭---》被销毁掉----》整个整个过程经历了一个周期----》vue帮咱们提......
  • vue之
    目录一、计算属性案例重写过滤二、监听(侦听)属性一、计算属性1计算属性是基于它们的依赖变量进行缓存的2计算属性只有在它的相关依赖变量发生改变时才会重新求值,否则不会变(函数只要页面变化,就会重新运算)3计算属性就像Python中的property,可以把方法/函数伪装成属性4计算......
  • TDesign——投放时间段组件(48 * 7 位字符串)
    前言基于tdesignvue-next+ts实现参考:byte-weektime-picker内容<!--eslint-disableno-bitwise--><template><divclass="weektime"><divclass="weektime-main"><divclass="weektime-hd">......
  • Element 日期组件
    1.能选择的时间大于现在 <el-date-pickerv-model="formData.beginTime"type="datetime"value-format="YYYY-MM-DDHH:mm:ss"placeholder="请选择开始时间":disabledDate="disabledDateFn":disabled-hours="disabledHour......
  • (转)常见日志收集方案及相关组件
    原文:https://www.cnblogs.com/hujinzhong/p/15005523.html一、常见日志收集方案1.1、EFK​在Kubernetes集群上运行多个服务和应用程序时,日志收集系统可以帮助你快速分类和分析由Pod生成的大量日志数据。Kubernetes中比较流行的日志收集解决方案是Elasticsearch、Fluentd和Kiba......
  • uniapp主题切换功能的第一种实现方式(scss变量+vuex)
    随着用户端体验的不断提升,很多应用在上线的时候都要求做不同的主题,最基本的就是白天与夜间主题。就像b站app主题切换,像这样的uniapp因为能轻松实现多端发布而得到很多开发者的青睐,但每个端的实现也有可能不同,现我把已实现的功能一点点的大家分享给大家,须要的可以参考一下,可......
  • win11 安装 Vue
    Win安装VueVue官网文档vue官网下载node.jshttps://nodejs.org/en#安装v8.9以上的版本推荐v10及以上#我下载的版本9.5.1版本链接:https://pan.baidu.com/s/19ekl3NRo4vtfv1Dp5K9kog提取码:1zoi一直点击下一步进行安装。安装到你要的目录即可。 查看npm版本......