我做了一支笔,所以你可以看到我在说什么:https://codepen.io/cristian-ayala/pen/rNOWwOO?editors=1111
输入和段落都绑定到来自Vue (anioPicker)的值,但1秒后我使用jquery更改了值,但vue没有检测到更改,或者可能我没有正确注册事件。段落仍然显示2020年,即使我已经改变它,但在实际情况下仍然是2020年。Vue仅在我键入或删除某些内容时才会反映更改。你能告诉我我哪里做错了吗?
谢谢你的帮助。
var vm = new Vue({
el: '#appRESBAR',
data: {
anioPicker: 2020,
},
methods:{
},
watch: {
anioPicker: function(value) {
console.log("watched property",value);
}
}
});
$(window).on("load", function(e) {
setTimeout(function() {
$("#anioDate").val(2012);
console.log(document.querySelector('.yearpicker').value)
}, 1000);
});
.datePick {
display: inline-block;
background: #828282;
transform: skew(-10deg);
padding-left: 10px;
font-weight: 500;
padding-top: 0.5rem;
padding-bottom: 0.5rem;
padding-right: 10px;
margin-top: 0.5rem;
text-align: center;
margin-bottom: 0.5rem;
color: #ffffff;
}
.selectedDate {
background-color: #224abed6;
}
.styleInput{
margin: 0px;
width: 38px;
color: white;
background: #4466c8;
border: none;
padding: 0;
outline: none;
border-radius: 0;
}
<div id="appRESBAR" style="text-align: center;">
<div class="datePick selectedDate">
<input type="text" id="anioDate" class="yearpicker styleInput" style="margin: 0;" v-model="anioPicker"></input>
</div>
<p>La fecha es: {{ anioPicker }}</p>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
发布于 2020-04-22 03:00:33
Vue使用自己的VDom (虚拟DOM)来管理它的数据和组件。您正在修改底层的DOM实例,它不会将这些更改向上传播到VDom。
您必须改为在vue
实例中修改该值。
您可以通过直接更改本例中根vm
实例的值来完成此操作:
vm.anioPicker = 2012
https://stackoverflow.com/questions/61351057
复制相似问题