我的动态搜索有问题。我想找到id包含特定文本的div,它工作得很好,直到我尝试为ex找到带有重音字符的东西。Ł。
我正在使用这个选择器:
$('.user-row[id*='+searchText+']')我尝试过输入和
val().indexOf(searchText) > 0 但它也不起作用。
发布于 2014-12-22 00:53:45
我能想到的唯一问题是您没有使用HTML5。
HTML4.01规范规定ID标记必须以字母(A-Za-z)开头,后面可以是任意数量的字母、数字(0-9)、连字符(-)、下划线(_)、冒号(:)和句号(.)。
HTML5摆脱了对id属性的额外限制。
https://mathiasbynens.be/notes/html5-id-class
因此,在HTML5中,id中肯定允许使用特殊的重音字符,比如所描述的Ł。
演示的JSFiddle:http://jsfiddle.net/7cq25865/
$('.user-row[id*='+searchText+']')确实行得通。
发布于 2014-12-22 01:31:56
好吧,我犯了个愚蠢的错误。我使用php strtolower分配divs。然后我降低了搜索文本,但是ł不能处理重音字符,所以我的div被命名为Ł而不是strtolower。这就是为什么选择器没有找到它的原因。mb_strtolower确实起作用了。案例已结案:D
发布于 2018-03-06 13:47:04
我在这里发现了一个有趣的Jquery事实,虽然与这个问题无关。
Jquery ID选择器通常只选择第一个匹配的元素,但是对于任何包含重音字母的id名称,ID选择器将选择所有元素。
示例如下:
$('#lesschars').css({backgroundColor: 'blue'});
$('#someŁchars').css({backgroundColor: 'red'});<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="user-row" id="lesschars">ID with no accent, will select first element</div>
<div class="user-row" id="lesschars">ID with no accent, will select first element</div>
<br>
<div id="someŁchars" class="user-row">ID with accent, selects both</div>
<div id="someŁchars" class="user-row">ID with accent, selects both</div>
是的,我知道,在一个页面中不应该有相同的ID,但很高兴知道这一区别
https://stackoverflow.com/questions/27591381
复制相似问题