我正在使用 jQuery Mobile 和 knockout.js 开发移动网站。我有一个(一种)复杂的场景,jQuery Mobile 的弹出和列表视图以及弹出 div 内的敲除数据绑定,我无法让它工作。
我有一个嵌套的警报列表,如下所示。对于每一天,它都会创建一个列表分隔行。然后在每一天里面,每个闹钟都有一行。
<ul id="alarmslist" data-bind="foreach: days" data-role="listview">
<li data-role="list-divider"><span data-bind="text: date"></span></li>
<!-- ko foreach: alarms1 -->
<li>
<a href="#popupBasic" data-rel="popup"><span data-bind="text: alarmName"></span></a>
<section id="popupBasic" data-role="popup" data-corners="true" data-history="false" data-overlay-theme="a">
<a href="#" class="ui-btn-right" data-icon="delete" data-iconpos="notext" data-rel="back" data-role="button" data-theme="c">Close</a>
<ul data-role="listview" data-inset="true">
<li data-role="divider" data-theme="a">Alarm Options</li>
<li><section class="alarmDetail"><span data-bind="text: alarmID"></span></section></li>
<li><a href="#">Go to Data</a></li>
<li><a href="#">Acknowledge</a></li>
</ul>
</section>
</li>
<!-- /ko -->
</ul>
我需要将弹出窗口小部件附加到警报行,这样当单击 li 行时,弹出窗口会显示该行的选项列表。这应该适用于每一行。每行的选项将取决于 alarmID 键。
这就是问题发生的地方。我正在尝试对alarmID 字段(它是alarms1 数组的一部分)进行数据绑定,以便下一个操作知道如何处理正确的警报。但是,我得到一个敲除错误,因为它找不到alarmID()。我猜 jQuery Mobile 正在 DOM 底部创建弹出部分,远低于我为淘汰赛定义的视图和视图模型。
无论如何,有人知道如何“解决”这种情况吗?或者,知道解决方法吗?或者,甚至是其他一些解决方案?