首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >按id搜索带有重音字符的jQuery搜索目录

按id搜索带有重音字符的jQuery搜索目录
EN

Stack Overflow用户
提问于 2014-12-22 00:33:49
回答 3查看 872关注 0票数 1

我的动态搜索有问题。我想找到id包含特定文本的div,它工作得很好,直到我尝试为ex找到带有重音字符的东西。Ł。

我正在使用这个选择器:

代码语言:javascript
复制
$('.user-row[id*='+searchText+']')

我尝试过输入和

代码语言:javascript
复制
val().indexOf(searchText) > 0 

但它也不起作用。

EN

回答 3

Stack Overflow用户

发布于 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中肯定允许使用特殊的重音字符,比如所描述的Ł。

演示的JSFiddlehttp://jsfiddle.net/7cq25865/

代码语言:javascript
复制
$('.user-row[id*='+searchText+']')

确实行得通。

票数 3
EN

Stack Overflow用户

发布于 2014-12-22 01:31:56

好吧,我犯了个愚蠢的错误。我使用php strtolower分配divs。然后我降低了搜索文本,但是ł不能处理重音字符,所以我的div被命名为Ł而不是strtolower。这就是为什么选择器没有找到它的原因。mb_strtolower确实起作用了。案例已结案:D

票数 0
EN

Stack Overflow用户

发布于 2018-03-06 13:47:04

我在这里发现了一个有趣的Jquery事实,虽然与这个问题无关。

Jquery ID选择器通常只选择第一个匹配的元素,但是对于任何包含重音字母的id名称,ID选择器将选择所有元素。

示例如下:

代码语言:javascript
复制
$('#lesschars').css({backgroundColor: 'blue'});

$('#someŁchars').css({backgroundColor: 'red'});
代码语言:javascript
复制
<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,但很高兴知道这一区别

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27591381

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档