- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一个搜索模式,当用户按 s 时,它将运行一个搜索框。它可以工作,但有两个问题:
$("body").bind('keyup', function(event) {
if (event.which == 83) {
$('#search-modal').show();
}
});
最佳答案
我从评论中看到,您可能改变了申请中的方法,但考虑到它的学术值(value) - 回答所写的问题:
您可以使用 .on()
代替 .bind()
(自 jQuery 1.7 起已弃用) 和 .off()
添加/删除事件处理程序。
这将允许您根据需要打开/关闭该事件处理程序。
$("body").on('keyup', function(event) {
if (event.which == 83) {
$('#mdl').show();
$('body').off('keyup'); //the "s" will only work once
}
});
$('#mdl_closeX').click(function(){
$('#mdl').hide();
});
#mdl {
position: fixed;
top: 10%;
left: 25%;
background: wheat;
display:none;
}
#mdl_inner {padding:50px;}
#mdl_closeX{padding:5px;text-align:right;cursor:pointer;}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<div id="mdl">
<div id="mdl_closeX"> X </div>
<div id="mdl_inner">My Modal</div>
</div>
<h3>Click on the page body, then press the letter [ s ] </h3>
<p>The [s] binding will work only once. After closing the modal, pressing [s] will not open it again. </p>
<p>Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. </p>
<p>Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. </p>
<p>Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. </p>
下面是一个修改后的示例,展示了当用户位于输入字段时如何关闭事件处理程序:
$("body").on('keyup', function(event) {
if (event.which == 83) {
$('#mdl').show();
}
});
$('#mdl_closeX').click(function(){
$('#mdl').hide();
});
$('input').focus(function(){
$('body').off('keyup'); //the "s" will only work once
});
$('input').blur(function(){
$("body").on('keyup', function(event) {
if (event.which == 83) {
$('#mdl').show();
$('body').off('keyup'); //the "s" will only work once
}
});
});
#mdl {
position: fixed;
top: 10%;
left: 25%;
background: wheat;
display:none;
}
#mdl_inner {padding:50px;}
#mdl_closeX{padding:5px;text-align:right;cursor:pointer;}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<div id="mdl">
<div id="mdl_closeX"> X </div>
<div id="mdl_inner">My Modal</div>
</div>
<h3>Click on the page body, then press the letter [ s ] </h3>
<p>The [s] binding will work any time the user is NOT inside an input field. </p>
<div>
When click in the input field, the "s" will be normalized. Next, click anywhere else on the body and the "s" will once again open the modal.
<input type="text" />
</div>
这里是一个示例,展示如何分配 Ctrl s 来打开搜索模式,而不仅仅是字母 s。
因为“Ctrl+S”没有成对的键码,所以我们必须单独跟踪每个键。因此,我们使用全局变量来跟踪 CTRL 键是否已被按下,然后仅当 Ctrl 键被标记为按下时才监视“s”。
var ctrldn = false;
$("body").on('keydown', function(event) {
if (event.which == 17){
ctrldn = true;
}
});
$("body").on('keyup', function(event) {
if (event.which == 17){
ctrldn = false;
}
});
$("body").on('keydown', function(event) {
if (ctrldn && event.which == 83){
$('#mdl, #olay').show();
return false;
}
});
$('#mdl_closeX').click(function(){
$('#mdl, #olay').hide();
});
$('input').focus(function(){
ctrldn = false;
$('body').off('keyup'); //the "s" will only work once
});
$('input').blur(function(){
$("body").on('keyup', function(event) {
if (ctrldn && event.which == 83) {
$('#mdl').show();
$('body').off('keyup'); //the "s" will only work once
}
});
});
#olay{
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
background:black;
opacity: 0.6;
z-index:9998;
display:none;
}
#mdl {
position: fixed;
top: 10%;
left: 25%;
background: wheat;
z-index:9999;
display:none;
}
#mdl_inner {padding:50px;}
#mdl_closeX{padding:5px;text-align:right;cursor:pointer;}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<div id="olay"></div>
<div id="mdl">
<div id="mdl_closeX"> X </div>
<div id="mdl_inner">My Modal</div>
</div>
<h3>Click on the page body, then press [ Ctrl ] [ s ] </h3>
<p>[Ctrl] [s] will open the modal no matter where the user is, and will not interfere with the letter [s] by itself. </p>
<p><b>Note that it was necessary to use `return false` to suppress the default action of [Ctrl][s] within the browser</b></p>
<div>
When click in the input field, the "s" works like the letter "s", and [Ctrl] [s] will open the modal (even in the input field)
<input type="text" />
</div>
我还对第三个演示进行了一些调整,以向您展示如何将其变成真正的模式 - 因此不需要 jQueryUI 或任何其他预制模式。您可以看到它们在幕后如何工作。基本上,您需要一个覆盖层(只是覆盖整个屏幕的 div),其 z-index 高于页面上除模式对话框之外的任何其他内容。。然后,您需要模态对话框结构(只是一个普通的 div,里面有东西),它被定位(使用 z-index)位于覆盖层的顶部。是的,就是这么简单。
关于javascript - 停止输入字段内的按键弹出窗口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56514139/
我对 JavaScript 上的 onkeypress 事件有疑问。 是否可以仅检测 Cntl 键或 Alt 键?此时,如果同时按下 Cntl 和 m,则 onkeypress 事件可以触发单击。是否
我想知道按键中允许使用什么样的字符。它是否也生成一个符号下划线(_)?我总是得到一个带有 - 字母的按键。 最佳答案 按键使用修改过的 Base64 字母表: -0123456789ABCDEFGHI
我有以下格式的(格式错误的DITA)XML: BLARG BLARG Definition BLARG2 BLARG2 Definition BLARG3 BLARG3 Definition
我有两个单独的对象数组,如果特定键值匹配,我需要将它们合并。分析数据后可能更有意义: 数组 1 let categories = [ { id: 5, slug: 'category-5',
由于我是新手,所以我的低效编码给大家带来了巨大的麻烦,对此我提前表示歉意。 我正在尝试在 HTML5 Canvas 上使用 Javascript 制作一个非常基本的游戏,但我似乎找不到一种简单的方法来
我试图找出将多维数组中的对象 id 属性映射到共享相同 id 的另一个数组中的对象值的最佳方法。 举个例子,我有一个像这样的genre_ids数组: 0: {id: 1, name: 'sci-fi'
我有一个游戏,当按下一个键时,您可以通过将子弹添加到 Controller 类来发射子弹。这是代码来自 KeyPressed(); else if (key == KeyEvent.VK_Q && !
我想比较两个字典的长度以及每个字典中每个键、值对的长度。如果在查找时没有匹配项,我还需要能够打印出来。 我当前的代码似乎传递了长度标准,但在尝试匹配元素时失败: assert_that(len(mod
我正在寻找一种跨平台(Win 和 MacOS)方法来检测 C# 中 OpenGL 应用程序的按键。 以下有效,但仅适用于字母数字字符。 protected override void OnKeyPre
我正在 try catch 按键事件(向上和向下翻页),但根本没有收到任何按键事件。这是相关代码:构造函数: private MainLayout() { imageView = new Im
$(el).bind('blur keypress', function(event){ if(event.type == 'keypress' && event.keyCode != 13) r
我有这段代码: while (SDL_PollEvent(&event)) { if (event.type == SDL_KEYDOWN) { switch(event.key.keys
我正在使用下面的代码: $(document).keypress(function (e) { if (e.which === 68 || e.which === 100) {
我正在用 html 和 javascript 制作游戏。只是为了澄清,这不是重复或任何东西。没有什么可以给我我需要的答案。另外,在解释之前,我想说我对按键监听器没有任何问题,我的游戏知道何时按下按键以
我正在尝试用 Javascript 制作游戏,但目前我已经陷入停滞。我正在尝试检测按键并检查它们是否不断按下以移动 Angular 色。这是我正在使用的代码: var THREE; var keys;
我得到了多维数组。我想从每个子数组中删除/取消设置索引为 1 的值。我的数组 $data。 Array ( [3463] => Array ( [0]
我正在设计一个基于网络的会计软件。例如,每当用户按 N 键时,我想打开“新会计凭证”。并在他/她按下 S 键时打开“设置”。 我看到了一些基于 JavaScript 和 jQuery 的脚本。但它们并
阅读此主题后: Keypress events stopped working outside of "input" elements in Meteor after update to 0.5.2
所以,当我按下按钮 1“1 PLAY/STOP”时,按钮变成绿色,当我再次按下它时它会去除颜色。 如果我按下 button2“2 PLAY/STOP”,同样的事情会发生。 如果两个按钮之一播放而我按下
非常直接的问题。 只想按一个键盘键。像输入一样,使用 pywin auto。我不想在任何应用程序窗口的上下文中按下它。 只是键盘键的原始按键,如 a 或 enter 或退格。 最佳答案 只需使用 #
我是一名优秀的程序员,十分优秀!