我已经使用 Kendo UI 组合了一个小应用程序,它将用户输入存储在 Javascript 数组中,然后通过将文本添加到 div 来打印这些项目。除了文本,我还需要一个删除按钮来从数组中删除这些项目。
由于我在初始化 Kendo UI 后将删除按钮添加到 DOM,因此我假设我需要.kendoMobileButton()
在添加的每个按钮上使用该方法。如果我不这样做,我的按钮样式不正确,尽管被赋予了属性data-role="button"
。
不过,当我尝试使用这些按钮时,我无法让它们调用带有data-click="deleteNumber"
. 该功能似乎根本没有触发。有什么提示吗?
这是我拼凑的一个简单示例,说明了我的问题:http ://crocdoc.ifas.ufl.edu/files/kendo_example/
贴在这里方便参考:
<!DOCTYPE HTML>
<html>
<head>
<title>Example code</title>
<meta charset="utf-8">
<link rel="stylesheet" href="styles/kendo.mobile.all.min.css" type="text/css">
<script src="js/jquery.min.js"></script>
<script src="js/kendo.mobile.min.js"></script>
</head>
<body>
<div data-role="view" id="main">
<div data-role="header">
<div data-role="navbar">Generate numbers</div>
</div>
<a data-role="button" data-click="addNumber" style="display: block; margin: 10px; text-align: center;">Add number</a>
<div id="number_list" style="padding: 0 20px 0 20px;"></div>
</div>
<script>
var app = new kendo.mobile.Application();
var number_container = [];
var addNumber = function () {
var current_number = Math.floor(Math.random() * 1000 + 1);
number_container.push(current_number);
console.log(number_container);
var current_index = number_container.length - 1;
$('#number_list').append('Number ' + current_index + ': ' + current_number + ' <a id="delete_' + current_index + '" data-role="button" data-click="deleteNumber">Delete</a><br >');
$('#delete_'+current_index).kendoMobileButton();
};
var deleteNumber = function (e) {
console.log('Delete button hit');
var button_id = e.button.context.id;
button_id = button_id.replace('delete_', '');
button_id = parseFloat(button_id);
number_container.splice(button_id, 1);
$('#number_list').empty();
for (var i = 0; i < number_container.length; i++) {
$('#number_list').append('Number '+i+': '+number_container[i]+' <a id="delete_' + i + '" data-role="button" data-click="deleteNumber">Delete</a><br >');
}
};
</script>
</body>
</html>