- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这可能不是 Cordova /温泉特有的,但我是 Javascript 新手,所以我只是提供我认为相关的信息。我想知道引用模板化 HTML 元素的正确方法是什么。这是我目前正在做的事情(片段):
HTML:
<ons-navigator title="myApp" var="myNavigator">
<ons-page id="mainPage">
<ons-toolbar>
<div class="center">Title</div>
</ons-toolbar>
<ons-list>
<ons-list-item id="button" modifier="chevron">
Button Text
</ons-list-item>
</ons-list>
</ons-page>
</ons-navigator>
<ons-template id="newPage.html">
<ons-page id="newPage">
<ons-toolbar>
<div class="left">
<ons-back-button>Back</ons-back-button>
</div>
<div class="center">Page Title</div>
</ons-toolbar>
<button id="submit-btn" class="button button--large">Submit</button><br>
</ons-page>
</ons-template>
Javascript:
(function () {
"use strict";
/* Event Registration */
document.addEventListener('deviceready', onDeviceReady.bind(this), false);
// Listening for pageinit event to grab submit button.
document.addEventListener("pageinit", function (event) {
console.log("init Fired!");
if (event.target.id == "newPage") {
initPage();
}
}, false);
function initPage() {
$('#submit-btn').on('click', doSomethingUseful);
}
function onDeviceReady() {
// Handle the Cordova pause and resume events
document.addEventListener( 'pause', onPause.bind( this ), false );
document.addEventListener('resume', onResume.bind(this), false);
// TODO: Cordova has been loaded. Perform any initialization that requires Cordova here.
$('#button').on('click', function () {
myNavigator.pushPage('newPage.html', { animation: 'slide' })
});
};
} )();
本质上,我正在等待 Onsen 发出 pageinit 事件信号,然后再从模板化页面抓取按钮。一旦页面加载,即按下“按钮”时,就会发送 pageinit 信号。
尽管这可行,但感觉应该有更好的方法来做到这一点。我似乎应该能够提前设置它们,而不是必须等待页面加载才能设置按钮处理程序和其他内容。但是,如果我尝试在加载页面之前访问模板化元素,它将不起作用(jQuery 选择器返回 null)。
仅供引用,我没有使用 Angular。 (大多数 Onsen 示例都是用 Angular 编写的,但我目前正在学习足够多的新东西,并且不想让其他东西在此时增加困惑。)
最佳答案
正如 @Munsterlander 提到的 - 你不能将事件附加到尚未添加到 DOM 的元素。目前,您正在做的事情被认为是最好的做事方式。所以我只是建议尝试简化现有代码,而不实际改变它的总体思路。例如:内联某些函数并使用 ons.ready
而不是 deviceready
。此代码的同等且更简单的版本可以是:
document.addEventListener("pageinit", function (event) {
console.log("init Fired!");
if (event.target.id == "newPage") {
$('#submit-btn').on('click', doSomethingUseful);
}
});
ons.ready(function () {
document.addEventListener( 'pause', onPause.bind( this ), false );
document.addEventListener('resume', onResume.bind(this), false);
// TODO: Cordova has been loaded. Perform any initialization that requires Cordova here.
$('#button').on('click', function () {
myNavigator.pushPage('newPage.html', { animation: 'slide' })
});
});
通常我还会建议使用页面 id 制作类似对象的东西。像这样的东西:
var handlers = {
newPage: function(e) { $('#submit-btn').click(doSomethingUseful); },
page2: function(e) { $('#submit-btn2').click(doSomethingUseful2); }
};
和
document.addEventListener('pageinit', function(e) {
if (handlers.hasOwnProperty(e.target.id)) {
handlers[e.target.id](e);
}
});
我想现在是时候得到你想要的真正答案了。由于在元素添加到 DOM 之前您无法监听元素,因此如果您愿意,您可以监听事件并过滤其目标,就像使用 pageinit
事件一样。使用 jQuery,有一种相对简单的方法可以做到这一点:
$(document).on(eventName, selector, handler);
所以你可以随时执行此操作
$(document).on('click', '#submit-btn', doSomethingUseful);
它会起作用,因为它将处理程序附加到文档而不是元素。因此,这适用于您将来添加到 DOM 的所有 #submit-btn
。 :)(尽管不建议这样做,但如果您愿意,您仍然可以这样做。)
关于javascript - 在 Cordova/Onsen 中引用模板化 HTML 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36972866/
我使用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
我是一名优秀的程序员,十分优秀!