- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 iOS cordova 应用程序。我有一个 navigator.notification.prompt
出现(如预期的那样)以允许用户重命名特定的 radio channel 。问题是,如果再次单击“重命名”按钮(即使在导航到其他页面等之后),提示显示的次数是在应用程序生命周期中被单击的次数。 (例如:如果这是第二次点击,它会出现两次。第三次,3 次。等等...)
Javascript:
//***ChannelDetails***//
var ChannelDetails = {
Load: function (id) {
Data.db.transaction(function (tx) {
tx.executeSql('SELECT * FROM Channels WHERE ID=?', [id], function (tx, results) {
$('#channel-info').empty().append(
$('<strong/>').html(results.rows.item(0).Name),
$('<p/>').html("Zone: " + results.rows.item(0).Zone),
$('<p/>').html("Channel: " + results.rows.item(0).Channel),
$('<p/>').html("Frequency: " + results.rows.item(0).Frequency)
);
$('#channel-rename').data('id', id).data('name', results.rows.item(0).Name).on('click', function () {
ChannelDetails.Rename($(this).data('id'), $(this).data('name'));
});
$('#channel-delete').attr('data-id', id).on('click', function () {
ChannelDetails.Delete($(this).attr('data-id'));
});
});
});
},
Rename: function (id, name) {
navigator.notification.prompt("Set a name for the channel:", function (results) {
if(results.buttonIndex === 1) {
Data.db.transaction(function (tx) {
tx.executeSql('UPDATE Channels SET Name=? WHERE ID=?',[results.input1,id]);
});
$('#channel-details').dialog('close');
$('#channel-list').empty();
RadioChannels.Load();
}
}, name, ["Save", "Cancel"]);
},
Delete: function (id) {
Data.db.transaction(function (tx) {
tx.executeSql('DELETE FROM Channels WHERE ID=?',[id]);
});
$('#channel-details').dialog('close');
$('#channel-list').empty();
RadioChannels.Load();
}
};
HTML:
<!--Radio Channels-->
<div id="radio-channels" data-role="page" data-theme="a">
<div data-role="header">
<a href="#home">Back</a>
<h1>Channels</h1>
</div>
<div data-role="content">
<a href="#add-channel" data-role="button">Add Channel</a>
<ul id="channel-list" data-role="listview" data-inset="true"></ul>
</div>
</div>
<!--Channel Details-->
<div id="channel-details" data-role="page" data-theme="a">
<div data-role="header">
<h1>Channel</h1>
</div>
<div data-role="content">
<div id="channel-info"></div>
<button id="channel-rename">Rename</button>
<button id="channel-delete">Delete</button>
</div>
</div>
这是非常令人困惑的行为。
编辑:
所以经过进一步测试我发现导致倍数的不是按钮被点击的次数,而是channel-details
页面被加载的次数。我将在下面发布它是如何打开的代码,因为这似乎以某种方式影响了它。请注意,我使用的是 jQuery-mobile,此页面作为对话框打开。
//***Radio Channels***//
var RadioChannels = {
Init: function () {
$('a[href=#radio-channels]').on('click', function () {RadioChannels.Load();});
},
Load: function () {
$('#channel-list').empty();
Data.db.transaction(function (tx) {
tx.executeSql('SELECT * FROM Channels', [], function (tx, results) {
var i;
for(i=0; i<results.rows.length; i++) {
$('#channel-list').append(
$('<li/>').append(
$('<a/>').attr('href', "#channel-details").attr('data-rel', "dialog").attr('data-id', results.rows.item(i).ID).append(
$('<strong/>').html(results.rows.item(i).Name),
$('<p/>').html("Zone: " + results.rows.item(i).Zone),
$('<p/>').html("Channel: " + results.rows.item(i).Channel),
$('<p/>').html("Frequency: " + results.rows.item(i).Frequency)
).on('click', function () {
ChannelDetails.Load($(this).attr('data-id'));
})
)
);
}
$('#channel-list').listview('refresh');
}, function (error) {alert(error.code + " " + error.message);});
});
}
};
另一个编辑
我将其切换回常规页面,而不是对话框,我得到了相同的结果...是否正在创建多个实例?这是内部错误吗?
最佳答案
根据您所说的,我认为您在多事件绑定(bind)方面遇到了问题。与经典网页不同,jQuery Mobile 是独一无二的,如果您不小心,您可以将多个事件绑定(bind)到单个对象。
首先以这段代码为例:
$('a[href=#radio-channels]').on('click', function () {RadioChannels.Load();});
应该是:
$('a[href=#radio-channels]').off('click').on('click', function () {RadioChannels.Load();});
如果想找到更多关于多事件绑定(bind)的信息以及如何解决它(通过示例),请查看我的其他答案: jQuery Mobile: document ready vs page events 并查找主题:防止多个事件绑定(bind)/触发。
关于jquery - iOS Cordova 用户提示多次显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16655919/
我使用plugman命令在cordova中创建了一个插件 它创建了所有必需的文件。然后我在插件中添加了android平台。 然后我尝试将它添加到 cordova 应用程序中。我成功添加了它,但是当我尝
我使用plugman命令在cordova中创建了一个插件 它创建了所有必需的文件。然后我在插件中添加了android平台。 然后我尝试将它添加到 cordova 应用程序中。我成功添加了它,但是当我尝
我正在尝试在较旧的 Atrix 上安装一个应用程序,在 S3 上运行良好。搜索论坛可能的问题是SDK版本较高(Atrix是4.0.4)。修复显然是在设置 API 级别。 但是当我运行 cordova
使用 cordova build在一个为期一年的项目中提出: :processDebugResources my_project/platforms/android/build/intermediat
我有一个可以创建文件的可运行应用程序。 我正在寻找一种工作后数小时从cordova应用程序中删除文件的方法。我似乎无法使其正常工作。 这是用于创建和删除文件的代码: function crea
有什么区别吗Cordova 构建 Android 和 Cordova 准备 Android 命令? Reference is added here 最佳答案 准备将您的 www Assets 和任何插
我检查了文档,但没有找到关于此命令的明确说明。 那么,有谁知道cordova prepare命令的作用是什么? 是否更新特定于平台的www文件夹? 如果是,它将复制根www的全部内容吗? 它会更新平台
我们正在开发正在使用Cordova(专用于Ionic)的移动应用程序,并且正在使用PhoneGap PushPlugin和Amazon SNS进行推送通知。反过来,这会撞到我们与Amazon SNS进
我正在使用Vue,Webpack和Cordova。 Videos 如果我在没有Cordova的情况下加载页面,并且在Firefox浏览器中,则可以使用Youtube视频上的全屏图
因此,我尝试在我的(正在运行的)Ionic应用程序中安装一个新插件,该文件名为https://ionicframework.com/docs/native/firebase-dynamic-links
我像这样安装了cordova: C:\Windows\system32>npm install -g cordova 我明白了: C:\Users\cyril\AppData\Roaming\npm\
我有一个 cordova 应用程序,我使用以下代码捕获了后退按钮: document.addEventListener("backbutton", function (e) { bac
如何在 Cordova 中的蓝牙设备和 Android/iOS 之间发送和接收一系列数据字节? 我的项目的详细信息: 我正在开发一个蓝牙传感器设备。设备以一系列字节的形式发送数据。它还对设备 API
我是 cordova 开发的新手。我使用 Onsen UI (1.2.1) 作为布局框架。ons-toolbar 上的标题有问题。 someTextHere 如果我在 ripple 上运行
我有一个启用了平台浏览器的 Cordova 应用程序。我想在 Chrome 中使用摄像头,但调用摄像头根本没有任何反馈。它在我的 Android 设备上就像一个魅力。 我通过这个命令启动:cordov
我对thid docs https://firebase.google.com/docs/android/setup#available_libraries中提到的根级和应用程序级的路径目录感到困惑
喜欢这些插件 https://github.com/ArchieGoodwin/SilentShot https://github.com/alongubkin/phonertc 他们没有 tarba
我有一个 Angular 2 应用程序,我正在将其构建到 cordova 中并部署到 Android/IOS。我没有使用 ionic,我见过许多使用 ionic 的解决方案,但我现在无法将整个项目转换
当我发出命令时,在带有 Cordova 的 Ionic 3 中: ionic cordova run android --emulate 它给出以下消息: BUILD FAILED in 3s
我无法在 ionic 5.2.4v 中安装软件包 cordova-res 并收到以下错误。 命令:cordova-res C:\hanu\cordova-res-master\cordova-res
我是一名优秀的程序员,十分优秀!