uniapp兼容问题处理总结

1、v-mode与:value.sync,使用了v-mode后子组件中执行 this.$emit('update:value', newVal);无效,但是改成:value.sync可以

但是要注意这个是vue2,vue3中没有value.sync,vue3 整合了,实际上的v-model就是:value.sync,后面演示,先看vue2

首先两个编译后的代码都一样

html 复制代码
<!-- 这两行代码 -->
<filter-query :value.sync="showFilterStatus">

<filter-query v-model="showFilterStatus">

<!-- 实际上被 Vue 编译为 -->
<filter-query 
  :value="showFilterStatus" 
  @update:value="showFilterStatus = $event"
>

然后在子组件中

javascript 复制代码
//v-mode可以中心配置这个选项,默认的值为  prop: 'value',   event: 'input'  
model: {
    prop: 'value',   
	event: 'update:value'   
},
//这个时都要写   
props: {
    value: {
	    type: Boolean,
		default: false
	}
},

上面是他们的相同点,那他们有什么不同呢:

v-model:

  • 表单输入设计的语法糖

  • 默认行为

html 复制代码
// 默认行为(无 model 配置时)
prop: 'value'
event: 'input

可以修改这个配置,比如父组件中

html 复制代码
<filter-query v-model="showFilterStatus">

子组件中

html 复制代码
model: {
    prop: 'value',
	event: 'update:value'
},

:prop.sync:

  • 任意属性的双向绑定设计,更通用,不限于表单场景

  • 默认行为(这个不可重新配置)

html 复制代码
// 固定模式
prop: 'value'  // 就是 .sync 前面的属性名
event: 'update:value'  // update: + 属性名

上面演示的是vue2的代码,下面看看vue3,vue3中没有value.sync,vue3 整合了,实际上的v-model就是:value.sync

javascript 复制代码
<!-- 父组件 -->
<filter-query v-model:value="showFilterStatus" />
javascript 复制代码
// Vue 3 自组件
const props = defineProps({
  value: {
    type: Boolean,
    default: false
  }
})

const emit = defineEmits(['update:value'])

const toggle = () => {
  emit('update:value', !props.value)
}

这里如果不写:value直接写<filter-query v-model="showFilterStatus" />的话默认编译的参数值为modeValue

衍生知识:计算属性

可以写重写计算属性的get set方法,比如下面

通过计算属性重写get set,当设置showFilterStatus的值时会执行set方法,正常在template中使用的时候执行get方法

javascript 复制代码
    
    computed: {
	    showFilterStatus: {
	      get() {
	        return this.value;
	      },
	      set(newVal) {
	        this.$emit('update:value', newVal);
	      }
	    }
	},

2、微信小程序不支持大小写自动转换

比如,在子组件中定义一个dataSource字段接收父组件传过来的值

javascript 复制代码
    props: {
		dataSource: {
			type: Object,
			required: false,
			default: () => {
				return {}
			}
		}
	},

在父组件中有可能写成data-source,正常可以但是小程序中这样就不行必须写成dataSource

javascript 复制代码
<NewsItem :data-source="item"></NewsItem>
//上面代码小程序中不支持
<NewsItem :dataSource="item"></NewsItem>
相关推荐
用户0136087566884 分钟前
前端支持的主要数据类型及其使用方式
前端
代码搬运媛10 分钟前
SOLID 原则在前端的应用
前端
lecepin26 分钟前
AI Coding 资讯 2025-11-17
前端
孟祥_成都29 分钟前
下一代组件的奥义在此!headless 组件构建思想探索!
前端·设计模式·架构
灰太狼大王灬39 分钟前
Telegram 自动打包上传机器人 通过 Telegram 消息触发项目的自动打包和上传。
前端·机器人
4***14901 小时前
SpringSecurity登录成功后跳转问题
前端
小徐敲java1 小时前
window使用phpStudy在nginx部署前端测试
运维·前端·nginx
Winslei1 小时前
【hvigor专栏】OpenHarmony应用开发-hvigor插件之动态修改应用hap文件名
前端
扑棱蛾子1 小时前
前端代码一键打包上传服务器?10分钟配好永久告别手动部署!
前端·node.js
q***T5831 小时前
前端路由懒加载实现,React与Vue
前端·vue.js·react.js