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

聊城网站建设哪家专业无锡效果图制作

聊城网站建设哪家专业,无锡效果图制作,口碑好网站建设哪家好,鸿梦社区wordpressuniapp 微信小程序:v-model双向绑定问题(自定义 props 名无效) 前言问题双向绑定示例使用 v-model使用 v-bind v-on使用 sync 修饰符 参考资料 前言 VUE中父子组件传递数据的基本套路: 父传子 props子传父 this.$emit(事件名, …

uniapp 微信小程序:v-model双向绑定问题(自定义 props 名无效)

  • 前言
  • 问题
  • 双向绑定示例
    • 使用 v-model
    • 使用 v-bind + v-on
    • 使用 sync 修饰符
  • 参考资料

前言

VUE中父子组件传递数据的基本套路:

  1. 父传子 props
  2. 子传父 this.$emit('事件名', '数据');
  3. 使用 sync 修饰符,实现支持同步数据

问题

在这里插入图片描述 在这里插入图片描述
因为用的是 uniapp 开发小程序,所以要考虑到兼容性问题,不要把自己当正经VUE2。
小程序虽然支持 v-model 指令,但不支持 model 选项。
所以要么子组件中声明默认的 value 这个 props 来接收值。
要么手动:绑定属性事件

双向绑定示例

使用 v-model

由于小程序不支持 model 选项。
这个方案中:子组件里只能使用 value 接收数据,更新时触发 input

  • 父组件
<template><view><view><text>父组件:{{ msg }}</text></view><vmodel-component v-model="msg"></vmodel-component></view>
</template><script>export default {data() {return { msg: '大家好,我是:使用 v-model' }},methods: {}}
</script><style>
</style>
  • 子组件
<template><view> <view> 子组件:{{value}}  </view><button @click="onclick" >更新</button></view>
</template><script>export default {data() {return {};},props:{value:{ type: String, default: "未收到父值" }},methods:{onclick(e){this.$emit('input', '我是笨笨'); // v-mode }}}
</script><style>
</style>

使用 v-bind + v-on

当然一般都会用简写形式:
v-bind:缩写为 :
v-on:缩写为 @

由于是自己手绑定,props事件名都可以自己定。
比如在子组件中我就用 msg 接收数据。
事件我自己取名叫 customEvent

<template><view><view><text>父组件:{{ msg }}</text></view><novmodel-component :msg="msg" @customEvent="e => msg = e"></novmodel-component><!-- <novmodel-component :msg="msg" @input=" msg = $event "></novmodel-component> --></view>
</template><script>export default {data() {return { msg: '大家好,我是:不使用 v-model' }},methods: {}}
</script><style>
</style>
  • 子组件
<template><view> <view> 子组件:{{msg}}  </view><button @click="this.$emit('customEvent', '我是笨笨')" >更新</button></view>
</template><script>export default {data() {return {};},props:{msg:{ type: String, default: "未收到父值" }},methods:{}}
</script><style>
</style>

使用 sync 修饰符

使用 sync 时可以自己决定绑到子组件的哪个 props 上,比如就绑到了 msg 上。
同步数据时触发 update:要更新的props

  • 父组件
<template><view><view><text>父组件:{{ msg }}</text></view><sync-component :msg.sync="msg"></sync-component></view>
</template><script>export default {data() {return { msg: '大家好,我是:使用 sync 修饰符,实现同步数据' }},methods: {}}
</script><style>
</style>
  • 子组件
<template><view> <view> 子组件:{{msg}}  </view><button @click="$emit('update:msg', '我是笨笨')" >更新</button></view>
</template><script>export default {data() {return {};},props: {msg: { type: String, default: "未收到父值" }},methods:{}}
</script><style>
</style>

参考资料

uniapp官方文档 :模板指令 v-model
uniapp官方文档 :.sync 修饰符

vue2官方文档:选项 model

http://www.yayakq.cn/news/587110/

相关文章:

  • 做影视后期应该关注哪些网站小城市门户网站建设方案
  • 立方米网站建设网站流量分布
  • 在征婚网站上认识做期货品牌推广的意义
  • 简约大气网站设计欣赏东莞知名网站推广
  • 人是用什么做的视频网站吗织梦5.7转wordpress
  • 李志自己做网站wap医院网站建设
  • 域名备案与网站不一致物流加盟信息网站
  • 建设银行关方网站家居企业网站建设讯息
  • 温州手机网站建设wmwl手机网站模板 导航
  • 东莞注塑切水口东莞网站建设市场营销策划方案
  • 网站编辑移动网站开发语言
  • 长沙网站建设 个人泸州小程序定制开发
  • 医院网站建设需求分析调研表做美食网站的意义
  • 网上花店网站建设怎样重新安装wordpress
  • 怎么做可以直播的网站吗服装网站建设风格
  • 深圳企业建站招聘wordpress 订阅号推送
  • 硅胶鞋垫移动网站建设产品设计培训机构排名
  • 网站设计网页版营口市城乡住房建设局网站
  • 紫色网站岳麓区营销型网站建设定制
  • 做产品封面的网站扫码进入网站如何做
  • 宁波网站seo公司铜陵网站制作公司
  • 系部网站建设中期检查表网页制作工具软件下载
  • 广州市网站建设 骏域动力西安个人做网站
  • 迪拜哪个网站是做网站的杭州做网站排名软件
  • 网站建设算入会计分录系统ui设计界面
  • 展示型企业网站营销目标主要有网站运维推广怎么做
  • 网站 短链接怎么做织梦dedecms网站内容页
  • 中小学生在线做试卷的网站眯眯扑克app哪个公司开发
  • 一流学科建设专题网站泉州网红餐厅
  • 免费做网站收录的先做网站还是先注册公司