自定义组件的 v-model

官网链接:自定义组件的 v-model
v-model相当于一个语法糖(简写)

<input v-model="value" type="text">
就相当于:
<input :value="value" @input="value=$event.target.value" type="text">

由上面代码可知:v-model 默认会利用名为 value 的属性 和名为 input 的事件,但是如果我们想用其他属性或事件呢?例如:

<input :checkd="value" @change="value=$event.target.checkd" type="check">

那么这时候我们就要自定义v-model,通过父子组件互相传值的形式。

子组件:
<template>
  <div>
    <input type="checkbox" @change="handleCheck" :checked="checkedMsg"></input>
  </div>
</template>

<script>
export default {
  props: ['checkedMsg'],
  methods: {
    handleCheck(e) {
      this.$emit('checkChange',e.target.checked)
    }
  }
}
</script>
可进一步简写为:
<template>
  <div>
    <input type="checkbox" @change="$emit('checkChange',$event.target.checked)" :checked="checkedMsg"></input>
  </div>
</template>

<script>
export default {
  props: ['checkedMsg'],
}
</script>
父组件:
<template>
  <div class="home">
    <h3>{{checkVal}}</h3>
    <ModelText :checkedMsg="checkVal" @checkChange="getChecked"/>
  </div>
</template>

<script>
import ModelText from '@/components/ModelText'
export default {
  components: {
    ModelText
  },
  data() {
    return {
      checkVal: false,
    }
  },
  methods: {
    getChecked(data) {
      this.checkVal = data;
    }
  }
}
</script>
可进一步简写为:
<template>
  <div class="home">
    <h3>{{checkVal}}</h3>
    <ModelText :checkedMsg="checkVal" @checkChange="checkVal = $event"/>
  </div>
</template>

<script>
import ModelText from '@/components/ModelText'
export default {
  components: {
    ModelText
  },
  data() {
    return {
      checkVal: false,
    }
  },
}
</script>

此外还可直接使用 v-model 语法糖:

子组件:
<template>
  <div>
    <input type="checkbox" @change="$emit('checkChange',$event.target.checked)" :checked="checkedMsg"></input>
  </div>
</template>

<script>
export default {
  props: ['checkedMsg'],
  model: {
    prop: 'checkedMsg',
    event: 'checkChange'
  },
}
</script>
父组件:
<template>
  <div class="home">
    <h3>{{checkVal}}</h3>
    <ModelText v-model="checkVal"/>
  </div>
</template>

<script>
import ModelText from '@/components/ModelText'
export default {
  components: {
    ModelText
  },
  data() {
    return {
      checkVal: false,
    }
  },
}
</script>

这样就实现v-model自定义组件,但是看到这里肯定有个疑问,
子组件中直接这样写就可以实现双向绑定了啊:

<template>
  <div>
    <p>{{checkedMsg}}</p>
    <input type="checkbox" @change="checkedMsg = $event.target.checked" :checked="checkedMsg"></input>
  </div>
</template>

<script>
export default {
  data() {
    return {
      checkedMsg: false,
    }
  }
}
</script>

这样是可以实现,但是咱们初衷是自定义v-model,假如多处需要check标签的双向绑定时,自定义v-model在每次用的时候只需要引入同一个子组件就方便多了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于python+pyqt5开发的俄罗斯方块游戏源码+使用说明.zip基于python+pyqt5开发的俄罗斯方块游戏源码+使用说明.zip 【优质项目推荐】 1.项目代码功能经验证ok,确保稳定可靠运行。欢迎下载使用!在使用过程中,如有问题或建议,请及时私信沟通,帮助解答。 2.项目主要针对各个计算机相关专业,包括计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师或企业员工使用。 3.项目具有丰富的拓展空间,不仅可作为入门进阶,也可直接作为毕设、课程设计、大作业、项目初期立项演示等用途。 4.如果基础还行,或热爱钻研,可基于此项目进行二次开发,DIY其他不同功能。 功能 播放音乐 暂停游戏 消除方块的音效 窗口自由拖拽 游戏存档 安装和运行 ### 1. 使用`pip` ```shell # csdn下载此项目源码解压重命名为PyQt5-Tetris(不要有中文路径) 进入到项目 cd PyQt5-Tetris # 使用pip安装依赖 pip install -r requirements.txt # 运行 python main.py ``` ### 2. 使用`pipenv` ```shell # csdn下载此项目源码解压重命名为PyQt5-Tetris(不要有中文路径) # 进入到项目 cd PyQt5-Tetris # 使用pipenv安装依赖 pipenv sync # 运行 pipenv run start ``` ### 3. 按键说明 - `A` - 向左移动 - `D`- 向右移动 - `W` - 变形 - `S` - 加速下降 - `P` - 暂停 - `ESC` - 退出程序 ## PyInstaller 打包 ### 1. 使用`pip` ```shell # 安装依赖 pip install -r requirements-dev.txt # 打包,打包成功之后exe文件在dist文件夹下 pyinstaller main.spec ``` ### 2. 使用`pipenv` ```shell # 安装依赖 pipenv install --dev # 打包,打包成功之后exe文件在dist文件夹下 pipenv run build ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值