我正在尝试将bootstrap-datepicker与Vue.js一起使用,尝试创建一个简单的日期选择器组件。问题是,当我写入输入框时,组件的数据会更新。但是当我使用日期选择器GUI时,它不起作用。数据没有更新。为什么?到底缺少了什么?
这是我的代码:
Vue.component('picker', {
'props': {
'date': {
'twoWay': true
}
},
'template': '\
<div class="form-group">\
<div class="input-group date datepicker">\
<input type="text" class="form-control" v-bind:value="this.date">\
<span class="input-group-addon">\
<span class="glyphicon glyphicon-calendar"></span>\
</span>\
</div>\
</div>',
'watch': {
'date': function(value) {
console.log('Updated!');
}
},
'mounted': function() {
$(this.$el.firstChild).datetimepicker();
}
});
app = new Vue({
'el': '#app',
'data': {}
});
<!DOCTYPE html>
<html>
<head>
<title></title>
<!-- JQuery -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!-- Transition ve Collapse -->
<script src="collapse.js"></script>
<script src="transition.js"></script>
<!-- Moment JS -->
<script src="moment-with-locales.min.js"></script>
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
<!-- Latest compiled and minified JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
<!-- Datetime picker -->
<script src="https://raw.githubusercontent.com/Eonasdan/bootstrap-datetimepicker/master/build/js/bootstrap-datetimepicker.min.js"></script>
<link rel="stylesheet" type="text/css" href="https://raw.githubusercontent.com/Eonasdan/bootstrap-datetimepicker/master/build/css/bootstrap-datetimepicker.min.css">
<script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
<div class="container">
<div id="app" class="row">
<div class='col-sm-6'>
<picker></picker>
</div>
</div>
</div>
<script type="text/javascript">
</script>
</body>
<script src="app.js"></script>
</html>
date
属性,但在模板的<picker></picker>
组件中找不到它的定义。 - Belmin Bedakdate
prop一个初始值。 @Saurabh 它是一个prop。所以我不需要在Vue实例中定义它。对吗? 更新的代码。 - nejdetckenobi$(...).datetimepicker不是一个函数
的错误信息。 - Roy J