更新
借助来自 @Ziv Weissman 的帮助和建议和 @Fribu我重写了整个自动完成功能。
如果有人需要他/她可以从here下载.
感谢 StackOverFlow 社区。
我正在创建一个 jquery 自动完成功能。我创建的函数在单个文本框上运行良好。但是,一旦我在同一页面的另一个文本框中实现它,它就会出现意外行为。它打开和关闭自动完成列表。
这是我的 autofill.js 代码:
function setUl(result) {
var $ul = $('<ul>');
if (result !== undefined) {
$.each(result, function (k, v) {
$ul.append('<li data-value="' + v.value + '">' + v.label + '</li>');
});
}
return $ul;
}
$.fn.autofill = function (options) {
if (options == undefined) {
options = {};
}
var $currentInput = $(this);
var autoCompleteData = $currentInput.data('autofill');
var listId='autofill-' + (new Date().getTime()).toString(16);
$currentInput.on('keyup focus', function (e) {
var query = $(this).val();
var result = $.grep(autoCompleteData, function (v) {
return v.label.search(new RegExp(query, 'i')) !== -1;
});
$ul = setUl(result, $currentInput);
$ul.attr('id', listId);
$ul.addClass('autofill-show');
$ul.attr('data-target',$currentInput.attr('id'));
var position = $currentInput.position();
$ul.css({
width: $currentInput.width() + parseInt($currentInput.css('padding-left'), 10) + parseInt($currentInput.css('padding-right'), 10),
position: 'absolute',
top: position.top + $currentInput.outerHeight(),
left: position.left
});
if ($ul.find('li').length >= 6) {
$ul.css({
height: '130px',
'overflow-y': 'scroll'
});
}
if (result !== undefined) {
if ($(e.target).attr('id') !== $currentInput.attr('id') && $($(e.target).parent()[0]).attr('id') !== listId) {
destroy($ul);
}
$currentInput.after($ul);
}
$currentInput.trigger('onChange', [query, result]);
});
$(document).on('click', '.autofill-show li', function (e) {
if($ul!==undefined && $($(this).parent()[0]).attr('id')==$ul.attr('id')){
$ul.trigger('onSelect', [$(this).text(), $(this).data('value')]);
}
e.stopImmediatePropagation();
});
$(document).on('onSelect', '#'+listId,function (e, label, value) {
$currentInput.val(label);
if ($.isFunction(options.onSelect)) {
options.onSelect(label, value);
}
if ($(e.target).attr('id') !== $currentInput.attr('id') && $($(e.target).parent()[0]).attr('id') !== listId) {
destroy($ul);
}
e.stopImmediatePropagation();
});
$(document).on('onChange', '#'+$currentInput.attr('id'), function (e, query, result) {
if($ul!==undefined && $($(this).parent()[0]).attr('id')==$ul.attr('id')) {
result = $.grep(autoCompleteData, function (v) {
return v.label.search(new RegExp('\^' + query + '\$', "gi")) !== -1;
});
if ($.isFunction(options.onChange)) {
options.onChange(query, result[0]);
}
}
e.stopImmediatePropagation();
});
$(document).on('click', function (e) {
console.log($(e.target));
if ($(e.target).attr('id') !== $currentInput.attr('id') && $($(e.target).parent()[0]).attr('id') !== listId) {
destroy($ul);
}
e.stopImmediatePropagation();
});
};
function destroy($ul) {
$ul.remove();
}
这是我的CSS:
.autofill-show{
list-style: outside none none;
padding: 0;
border: 1px solid #ccc;
margin:0;
z-index: 9999999;
}
.autofill-show li{
border: 1px solid #ccc;
text-align: center;
background: #fff;
}
.autofill-show li:hover{
background: #9bcea3;
cursor: pointer;
}
这就是我调用函数的方式:
$('#autofill').autofill();
$('#autofill_2').autofill();
这是 fiddle 链接。 https://jsfiddle.net/saineshmamgain/cs6g13q9/2/
最佳答案
正如我提到的以及其他人的帮助,这是您的事件和选择器的问题。
一种解决方案是向创建的 UL 添加唯一 ID,而不是“基于日期时间”。 每次您将销毁一个特定的 ID,然后重新创建它。 事件将通过 HTML(添加 onclick=...)触发,并使用 jQUERY 处理当前/父级。
我已经更新了这个 fiddle
它可能有一些我没有时间完善的东西,我会把它留给你。
解决方案看起来像这样:
function setUl(result) {
var $ul = $('<ul>');
if (result !== undefined) {
$.each(result, function (k, v) {
$ul.append('<li data-value="' + v.value + '" onclick="clickHandle(this)">' + v.label + '</li>');
});
}
return $ul;
}
function clickHandle(ele){
var label = $(ele).text();
var value = $(ele).data('value');
var inputId = $(ele).parent("ul").attr("data-target");
$('#'+inputId).val(label);
if ($.isFunction(options.onSelect)) {
options.onSelect(label, value);
}
}
$.fn.autofill = function (options) {
if (options == undefined) {
options = {};
}
var $currentInput = $(this);
console.log($($currentInput).attr('id'));
var autoCompleteData = $currentInput.data('autofill');
var listId='autofill_' + $currentInput.attr('id');
$currentInput.on('keyup focus', function (e) {
var query = $(this).val();
var result = $.grep(autoCompleteData, function (v) {
return v.label.search(new RegExp(query, 'i')) !== -1;
});
if($('#'+listId)){
$('#'+listId).remove();
}
$ul = setUl(result, $currentInput);
$ul.attr('id',listId);
$ul.addClass('autofill-show');
$ul.attr('data-target',$currentInput.attr('id'));
var position = $currentInput.position();
$ul.css({
width: $currentInput.width() + parseInt($currentInput.css('padding-left'), 10) + parseInt($currentInput.css('padding-right'), 10),
position: 'absolute',
top: position.top + $currentInput.outerHeight(),
left: position.left
});
if ($ul.find('li').length >= 6) {
$ul.css({
height: '130px',
'overflow-y': 'scroll'
});
}
if (result !== undefined) {
destroy($ul);
$currentInput.after($ul);
}
$currentInput.trigger('onChange', [query, result]);
});
//end key up
$('#'+listId).on('onSelect',function (e, label, value) {
$currentInput.val(label);
if ($.isFunction(options.onSelect)) {
options.onSelect(label, value);
}
destroy($ul);
e.stopImmediatePropagation();
});
$(document).on('onChange', '#'+$currentInput.attr('id'), function (e, query, result) {
if($ul!==undefined && $($(this).parent()[0]).attr('id')==$ul.attr('id')) {
result = $.grep(autoCompleteData, function (v) {
return v.label.search(new RegExp('\^' + query + '\$', "gi")) !== -1;
});
if ($.isFunction(options.onChange)) {
options.onChange(query, result[0]);
}
}
e.stopImmediatePropagation();
});
$currentInput.on('blur', function (e) {
window.setTimeout(function(){
destroy($ul);
}, 100);
});
};
function destroy($ul) {
$ul.remove();
}
关于javascript - jquery中的自定义自动完成功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38450772/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢