当前位置: 首页 > news >正文

政府单位有必要网站建设吗最近几天的新闻大事

政府单位有必要网站建设吗,最近几天的新闻大事,2024疫情最新数据消息,wordpress 英文采集何为组件间双向绑定 我们都知道当父组件改变了某个值后,如果这个值传给了子组件,那么子组件也会自动跟着改变,但是这是单向的,使用v-bind的方式,即子组件可以使用父组件的值,但是不能改变这个值。组件间的…

何为组件间双向绑定

我们都知道当父组件改变了某个值后,如果这个值传给了子组件,那么子组件也会自动跟着改变,但是这是单向的,使用v-bind的方式,即子组件可以使用父组件的值,但是不能改变这个值。组件间的双向绑定就是对于父组件的变更,子组件可以感知到,同样对于子组件的变更,父组件也可以感知到。这个过程是自动的。Vue中的双向绑定用v-model来实现

示例解析

这里我们还是以一个计数器组件来介绍Vue的双向绑定,我们定义一个Div显示一个数,当我们点击这个数的时候,让这个数加1,代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>组件间双向绑定</title><script src="https://unpkg.com/vue@next"></script>
</head>
<body><div id="root"></div>
</body>
<script>const app = Vue.createApp({data() {return {count:1}},methods:{handleCountOneChange(count){this.count = count;}},template: `<div><counter v-model:count = "count"  @change-count-one="handleCountOneChange"/></div>`});app.component('counter',{props:['count'],methods: {handleItemClick(){this.$emit('change-count-one',this.count + 1);},},template:`<div @click="handleItemClick">{{count}}</div>`});const vm = app.mount('#root');
</script>
</html>

在之前我们要将父组件传过来的值做加一操作的时候,由于是单向数据流,我们只能把父组件传来的值先拷贝一份到子组件,然后让子组件去改变自己的这个值来达到子组件的计数效果,本节所讲的双向数据绑定可以在子组件中将这个值加一后传到父组件,父组件收到这个值以后又会同步给子组件,这样就完成了一个计数器。如上面代码所示,父组件通过v-model的方式将count传给子组件,子组件收到这个值后,当用户点击了div后,就会执行handleItemClick方法,这个方法会通过事件的方式,将count+1的值通知给父组件,父子组件由于是双向绑定的,所以这个count的值又会被子组件感知到然后子组件就显示了count+1 的值了,如此循环,点击一次,值就加一。就完成了counter组件的计数功能了。

这里需要注意的是,父组件传递值的时候用法是: v-model:count = "count" 不要忘记后面的“:count”少了是无法显示的

那假设我们不想使用:count的方式呢,那就可以用指定的一个关键字modelValue代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>组件间双向绑定</title><script src="https://unpkg.com/vue@next"></script>
</head>
<body><div id="root"></div>
</body>
<script>const app = Vue.createApp({data() {return {count:1}},methods:{handleCountOneChange(count){this.count = count;}},template: `<div><counter v-model = "count"  @change-count-one="handleCountOneChange"/></div>`});app.component('counter',{props:['modelValue'],methods: {handleItemClick(){this.$emit('change-count-one',this.modelValue + 1);},},template:`<div @click="handleItemClick">{{modelValue}}</div>`});const vm = app.mount('#root');
</script>
</html>

注意此处只能叫modelValue,其他的名字都不可以

总结

其实本文的内容非常简单,就是使用v-model来实现vue组件之间的双向绑定,这里面有个事件的概念,就是 this.$emit('change-count-one',this.count + 1);这个,这个可以理解成一个事件通过$emit()发送,父组件通过@change-count-one="handleCountOneChange"去监听,然后执行对应的操作。这个下次讲。本章就只讲通过v-model的方式来实现组件间双向绑定,但是需要注意父组件传值的属性名若要用自己的值就用v-model:自定义属性名 = "data()方法中定义的值",的方式,子组件通过prop:['自定义属性值']方式接收,或者是使用modelValue作为传值的属性名

http://www.wooajung.com/news/23645.html

相关文章:

  • 威海外贸网站建设联系方式google推广妙招
  • 自己做网站页面企业培训课程清单
  • 免流服务器沈阳seo网站推广
  • 南山网站建设公司乐云seo品牌推广方案案例
  • 黑网站代码制作培训课
  • 网站的域名不能登录哪些平台可以发布软文
  • 如何在电脑里做网站百度官方网
  • wordpress api网站更新seo
  • 免费手机wap建站网站404页面怎么做
  • 小蓝网页浏览器seo岗位是什么意思
  • 企业展示建设网站微信推广方案
  • 武汉做网站优化多少钱关键词搜索
  • 自己建网站做那个模块好北京优化网站推广
  • 四大门户网站创始人市场营销模式有哪些
  • 十大进口跨境电商平台北京seo编辑
  • 唐山网站制作系统关键词优化按天计费
  • 政府网站建设的有关规定搜索网页内容
  • 坂田网站建设推广公司网站策划方案书
  • 企业多语言网站开源百度正式员工工资待遇
  • 上海网站建设公司湖南网站制作公司
  • 免费网站你知道我的意思的seo实战
  • 广州营销型网站建设团队今日军事新闻
  • 凡客诚品官网网址seo效果最好的是
  • 分销平台是什么意思百度关键词seo
  • 免费企业自助建站平台网络舆情分析报告
  • 做旅行社的都是在哪网站拿票seo站外优化平台
  • b2b2c平台网站建设人民日报今日新闻
  • ui工作好找工作吗seo排名优化哪家好
  • 中石化建设工程电子招投标交易网seo搜索引擎优化兴盛优选
  • 推广互联网工具是什么意思seo建设