- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
这可能是大多数阅读的基础,但我似乎无法理解。
如果在一定宽度下,我想执行一个小测试函数。当屏幕旋转或调整大小超过该宽度时,我希望该功能停止工作。为简单起见,这里有一些示例代码。
enquire.register("screen and (max-width:500px)",{
match : function() {
$(".block .block-title").click(function(){
alert("Hello World!");
});
}
}).listen();
因此,如果页面加载超过 500 像素,它会按预期工作。单击不会执行。如果页面以 500 像素或以下加载,则执行点击功能。唯一的问题是,如果您调整视口(viewport)大小或将方向更改为 500 像素以上,该函数仍会执行。我希望能够禁用它。
我实际上想在这里做的现实世界场景是我有一个包含 4 个项目的未排序列表。超过一定宽度,它们会立即显示。如果在一定宽度下,我只想隐藏它们并单击显示它们。我知道有几种方法可以做到这一点(.toggle()、.toggleClass("myclass") 等)。
我已经这样做了很多次,但我总是遇到进入/退出断点和未重置或按预期工作的事情。通常这无关紧要,但最近在我的一些用例中它变得很重要。
我知道不匹配选项,但我不确定如何真正杀死上面的匹配函数。
enquire.register("screen and (max-width:500px)",{
match : function() {
$(".block .block-title").click(function(){
alert("Hello World!");
});
},
{
unmatch : function() {
// what do I do here do kill above?
}
}
}).listen();
如有任何帮助,我们将不胜感激。我很确定它会对我目前的情况有所帮助,但也会帮助我扩展 enquire.js 的其他知识。
谢谢。
编辑:我忘了提...如果您将页面加载到 500 像素以下,然后调整大小或调整到比 500 像素更宽,然后返回到 500 像素以下,点击功能将不再起作用。这也让我感到困惑。我基本上希望它在 500px 以下时无论如何都能工作,而在超过 500px 时根本无法工作。
最佳答案
我是 enquire.js 的作者,希望我能帮到你 ;-)
基本上,您希望在匹配时添加事件处理程序并在不匹配时删除事件处理程序。您似乎掌握了上面如何执行此操作的要点,但是您的语法有点错误。一旦语法得到纠正,只需一些 jQuery 知识即可删除点击处理程序。
那么让我们看看语法应该如何:
enquire.register("screen and (max-width:500px)", {
match: function() {
//match code here
},
unmatch: function() {
//unmatch code here
}
}).listen();
请注意,匹配和取消匹配是提供给register
的单个对象的一部分。
理想情况下,您应该将其放入文档就绪回调中。要分配您的点击处理程序,请使用 jQuery 的 on
方法,因为这允许您使用 off
方法取消分配:
$(".block .block-title").on("click", function() {
alert("hello");
});
$(".block .block-title").off("click");
这很棒,因为您甚至可以为您的事件命名空间,请阅读 jQuery 文档以了解更多详细信息。所以把它们放在一起,我们会有这样的:
$(document).ready(function() {
var $target = $(".block .block-title");
enquire.register("screen and (max-width:500px)", {
match: function() {
$target.on("click", function() {
alert("Hello World!");
});
},
unmatch: function() {
$target.off("click");
}
}).listen();
});
您可以在这里找到一个工作示例:http://jsfiddle.net/WickyNilliams/EHKQj/
那应该就是您所需要的了:)希望对您有所帮助!
关于javascript - 使用 enquire.js 退出匹配的断点时销毁函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13096866/
我目前正在为 Cocoa/Objective-C 项目编写一个脚本来完全自动化我的编译-运行-调试过程。 我的最后一行代码是: lldb -f Build/MyApp.app -o "run" 这实际
我有一个带有登录屏幕的脚本,如果按下取消按钮,我想完全退出该应用程序。我尝试了 3 种方法: 系统退出() QApplication.quit() QCoreApplication.instance(
我有一个 Flash 应用程序,可以重定向到另一个页面。我很乐意捕获任何其他窗口卸载事件(单击链接/提交表单)并警告用户他们将丢失 Flash 应用程序中的进度。 但是,我找不到任何方法来判断 URL
我正在尝试在 Ubuntu 上用 Python 编写一个简单的程序,它将在播放视频完成后关闭/退出/退出 VLC Player。 能否请您指导我应该在我的程序中添加什么以获得我需要的结果。 impor
我在 Lynda.com 上学习 PHP 2 视频时遇到了一个问题,因为讲师似乎忽略了告诉我们他在视频中执行的步骤之一。我在这里上传了相关视频http://www.youtube.com/watch?
某天在群内有同学问到,在python下我用input或者raw_input都得输入完后回车才能获取到输入的值,那如何实现任意键退出暂停等功能呢,我当时也没有多想,因为接触python时间也不算长,主
我按顺序调用了几个函数(我无法编辑),但有些函数会重定向用户,所以我永远不会进入下一个函数。 我正在调用一个第三方函数,它调用了我能够阻止的 wp_redirect(),但是下一行是 exit;我不知
终止/退出主函数的 D 方式是什么? import std.stdio; import core.thread; void main() { int i; while (i <= 5)
我正在申请写作。用户可以打开应用程序、写一些文本、保存他们的工作等。 我试图做到这一点,以便点击 window close按钮将提示用户 (a) 保存他们的工作(如有必要)或 (b) 退出。 我正在尝
我正在通过在 repl 中检查别人的代码来玩弄它。 它不断调用 System/exit,这导致我的 repl 崩溃。这真是令人气愤。 在我有权访问的所有代码中,我都模拟了调用。 但它也会调用一些我没有
我正在使用 subprocess执行mimic的模块程序(指定 here )。下面的代码成功地读取了一些文本并写入了一个 mp3 文件。 import subprocess proc = subpro
退出 .then 范围后数组上的值被清除 在下面的代码中tableValues1.length 给我正确的长度,直到它位于每个循环内当它退出时,作用域数组长度为零。 请谁能帮我解决这个问题 - 谢谢
我正在尝试为 s3cmd 编写一个 docker 镜像。当我通过 docker-compose 运行从 Dockerfile 构建的图像时,容器在 docker compose run 命令之前退出。
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicate: Quitting an application - is that frowned upon? 我编写了一个 And
我遇到 Selenium WebDriver 仅执行一次后退出 for 循环的问题。据推测,这是获取内容和在加载页面之前启动循环的问题。是否有可能让 webdriver 等待页面加载? List al
#include #include #include #include "Player.h" using namespace std; void PlayerMenu(); int main()
class Test{ public static void main(String args[]) { Patron list[] = new PatronData(
我正在做一些作业,遇到了这个问题。 Write a program that reads several lines of text and prints a table indicating the
我正在用 C 创建一个简单的 Linux 命令 shell。我无法理解我的代码在哪里出现问题。 “commands”是我希望作为一个父进程的子进程同时执行的 Linux 命令字符串列表。当所有执行完成
我的控制台应用程序有点问题。应用程序应该从用户那里获取数字并将它们添加到列表中,但是如果输入是“c”,它应该关闭。我不知道如何在不使用 Scanner.nextLine() 挂起应用程序并退出循环的情
我是一名优秀的程序员,十分优秀!