Vue未检测到JQuery或JS所做的更改

时间:2020-04-21 18:56:30

标签: javascript jquery vue.js vue-reactivity

我制作了一支笔,以便您可以看到我在说什么:https://codepen.io/cristian-ayala/pen/rNOWwOO?editors=1111

输入和段落均绑定到Vue(anioPicker)的值,但是1秒钟后,我使用jquery更改了该值,但vue未检测到更改,或者我未正确注册该事件。即使我已经更改,段落仍显示2020,但在vue实例中仍然是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>

1 个答案:

答案 0 :(得分:1)

Vue使用其自己的VDom(虚拟DOM)来管理其数据和组件。您正在修改基础DOM实例,该实例不会将这些更改向上传播到VDom。

您必须改为在vue实例中修改值。

您可以通过直接更改根vm实例的值来实现此目的:

vm.anioPicker = 2012
相关问题