博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JQuery中的id选择器含有特殊字符时,不能选中dom元素的解决方法
阅读量:2095 次
发布时间:2019-04-29

本文共 996 字,大约阅读时间需要 3 分钟。

1、jquery类库在我们实际项目中用的很多,大家经常需要根据控件的id,获取对应的html元素。但是:当id含有特殊字符的时候,是不能选中的

2、自己简单的测试了下,jquery的id选择器只支持,单词、阿拉伯数字、下划线、中划线。其中单词,包括英文字母、汉字,但是控件id属于客户不可见内容,实际中开发人员是不用汉字作为id的,这里不考虑。

3、自己写了一个工具方法,开人人员只要将id转义后,jquery就能选中了,不用再考特殊字符的问题。代码是基于jquery1.6版本。

function escapeJquery(srcString){	// 转义之后的结果	var escapseResult = srcString;	// javascript正则表达式中的特殊字符	var jsSpecialChars = ["\\", "^", "$", "*", "?", ".", "+", "(", ")", "[",			"]", "|", "{", "}"];	// jquery中的特殊字符,不是正则表达式中的特殊字符	var jquerySpecialChars = ["~", "`", "@", "#", "%", "&", "=", "'", "\"",			":", ";", "<", ">", ",", "/"];	for (var i = 0; i < jsSpecialChars.length; i++) {		escapseResult = escapseResult.replace(new RegExp("\\"								+ jsSpecialChars[i], "g"), "\\"						+ jsSpecialChars[i]);	}	for (var i = 0; i < jquerySpecialChars.length; i++) {		escapseResult = escapseResult.replace(new RegExp(jquerySpecialChars[i],						"g"), "\\" + jquerySpecialChars[i]);	}	return escapseResult;}

说明随着JQuery版本的演进,对特殊字符的支持应该会越来越好。为了不给自己找麻烦,特殊字符还是能不用则不用。

转载地址:http://ejdhf.baihongyu.com/

你可能感兴趣的文章
日本語の記号の読み方
查看>>
计算机英语编程中一些单词
查看>>
JavaScript 经典例子
查看>>
判断数据的JS代码
查看>>
js按键事件说明
查看>>
AJAX 设计制作 在公司弄的 非得要做出这个养的 真晕!
查看>>
Linux 查看文件大小
查看>>
Java并发编程:线程池的使用
查看>>
redis单机及其集群的搭建
查看>>
Java多线程学习
查看>>
检查Linux服务器性能
查看>>
Java 8新的时间日期库
查看>>
Chrome开发者工具
查看>>
【LEETCODE】102-Binary Tree Level Order Traversal
查看>>
【LEETCODE】106-Construct Binary Tree from Inorder and Postorder Traversal
查看>>
【LEETCODE】202-Happy Number
查看>>
和机器学习和计算机视觉相关的数学
查看>>
十个值得一试的开源深度学习框架
查看>>
【LEETCODE】240-Search a 2D Matrix II
查看>>
【LEETCODE】53-Maximum Subarray
查看>>