在前端与后台交互的时候我们通常都需要将后台传递的数据绑定到html中,这个绑定数据的方式我们通常是使用jquery或者使用原生的innerHTML进行绑定,当然也可以使用artTemplate模板来绑定数据,那么artTemplate模板它绑定数据的原理是什么呢?其实它就是利用了replace()方法。
对于正则replace约定了一个特殊标记符”$”:
1)、$i(i取值范围1~99):表示从左到右正则子表达式所匹配的文本
2)、$&:表示与正则表达式匹配的全部文本
3)、$`(`:1旁边的那个键):表示匹配字符串的左边文本
4)、$'(':单引号):表示匹配字符串的右边文本
5)、$$:表示$转移
<script type="text/javascript">
/*要求将字符串中所有的a全部用A代替*/
var str = "javascript is great script language!";
//只会将第一个匹配到的a替换成A
console.log(str.replace("a","A"));
//只会将第一个匹配到的a替换成A。因为没有在全局范围内查找
console.log(str.replace(/a/,"A"));
//所有a都被替换成了A
console.log(str.replace(/a/g,"A"));
</script>
<script type="text/javascript">
/*要求将下面这个元素中的unabled类移除掉*/
<div class=”confirm-btn unabled mb-10” id=”j_confirm_btn”>提交</div>
var classname = document.getElementById(“j_confirm_btn”).className;
/*(^|\\s)表示匹配字符串开头或字符串前面的空格,(\\s|$)表示匹配字符串结尾或字符串后面的空格*/
var newClassName = classname.replace(/(^|\\s)unabled(\\s|$)/,””);
document.getElementById(“j_confirm_btn”).className = newClassName;
</script>
<script>
/*要求:将字符串中的双引号用"-"代替*/
var str = '"a", "b"';
console.log(str.replace(/"[^"]*"/g,"-$1-"));
//输出结果为:-$1-, -$1-
/*解释:$1就是前面正则(/"[^"]*"/g)所匹配到的每一个字符。*/
</script>
<script>
/*要求:将下面字符串替换成:javascript is fn.it is a good script language*/
var str = "javascript is a good script language";
console.log(str.replace(/(javascript)\s*(is)/g,"$1 $2 fn.it $2"));
/*解释:每一对括号都代表一个分组,从左往右分别代表第一个分组,第二个分组...;如上"*(javascript)"为第一个分组,
"(is)"为第二个分组。$1就代表第一个分组匹配的内容,$2就代表第二个分组匹配的内容,依此类推...*/
</script>
当我们使用谷歌搜索的时候我们会发现我们搜索的关键字都被高亮显示了,那么这种效果用JavaScript能否显示呢?答案是可以的,使用replace()很轻松就搞定了。
<script>
/*要求:将下列字符串中的"java"用红色字体显示*/
var str = "Netscape在最初将其脚本语言命名为LiveScript,后来Netscape在与Sun合作之后将其改名为JavaScript。
JavaScript最初受Java启发而开始设计的,目的之一就是“看上去像Java”,因此语法上有类似之处,一些名称和命名规范也借自Java。
但JavaScript的主要设计原则源自Self和Scheme。";
document.write(str.replace(/(java)/gi,'<span style="color: red;font-weight: 800;">$1</span>'));
/*解释:必须要开启全局搜索和忽略大小写,否则匹配不到所有的”java”字符*/
</script>
在正则中,当我们需要匹配两个或多个连续的相同的字符的时候,就需要用到反向引用了,查找连续重复的字符是反向引用最简单却也是最有用的应用之一。上面的”$i”也是反向分组的一种形式,这里再介绍另一种反向分组。
<script type="text/javascript">
/* /ab(cd)\1e/ 这里的 \1 表示把第1个分组的内容重复一遍*/
console.log(/ab(cd)\1e/.test("abcde"));//false
console.log(/ab(cd)\1e/.test("abcdcde"));//true
/*要求:将下列字符串中相领重复的部分删除掉"*/
var str = "abbcccdeee";
var newStr = str.replace(/(\w)\1+/g,"$1");
console.log(newStr); // abcde
</script>
replace函数的第二个参数不仅可以是一个字符,还可以是一个函数!
<script>
var str = "bbabc";
var newStr = str.replace(/(a)(b)/g,function (){
console.log(arguments);//["ab", "a", "b", 2, "bbabc"]
/*参数依次为:
1、整个正则表达式所匹配到的字符串----"ab"
2、第一个分组匹配到的字符串,第二个分组所匹配到的字符串....依次类推一直 到最后一个分组----"a,b"
3、此次匹配在源字符串中的下标,返回的是第一个匹配到的字符的下标----2
4、源字符串----"bbabc"
*/
})
</script>
<script>
/*要求:将下列字符串中的所有首字母大写*/
var str = "Tomorrow may not be better, but better tomorrow will surely come!";
var newStr = str.replace(/\b\w+\b/gi,function (matchStr){
console.log(matchStr);//匹配到的字符
return matchStr.substr(0,1).toUpperCase() + matchStr.substr(1);
});
console.log(newStr);
</script>
<h1>周星驰喜剧电影:</h1>
<div id="content"></div>
<script type="text/javascript">
var data = {
name: "功夫",
protagonist: "周星驰"
},
domStr = '<div><span>名称:</span><span>{{name}}</span></div><div><span>导演:</span><span>{{protagonist}}</span> </div>';
document.getElementById("content").innerHTML = formatString(domStr,data);
/*绑定数据的核心就是使用正则进行匹配*/
function formatString(str,data){
return str.replace(/{{(\w+)}}/g,function (matchingStr,group1){
return data[group1];
});
}
</script>
<script>
var str = "i am a good man";
var newStr = str.replace(/good/g,"$&");
console.log(newStr);//结果:输出i am a good man
/*解释:在这里”$&”就是与正则表达式进行匹配的那个源字符串*/
</script>
<script>
/*要求:将"i am a good man"替换成"i am a good-gond man" */
var str = "i am a good man";
var newStr = str.replace(/good/g,"$&-$&");
console.log(newStr);
/*解释:在这里”$&”可以获取到前面正则表达式匹配的内容,如上面的”$&”就是正则表达式匹配到的”good”*/
</script>
<script>
/*要求:将下列字符串替换成"java-java is a good script"*/
var str = "javascript is a good script";
var newStr = str.replace(/script/,"-$`");
console.log(newStr)
/*解释:"$`"获取的是正则左边的内容,如上正则中"script"字符前面的是"java","-$`"就是"-java","-$`"会把script替换掉。*/
</script>
<script>
/*要求:将下列字符替换成"java is a good language!it is a good script is a good script"*/
var str = "javascript is a good script";
var newStr = str.replace(/script/," is a good language!it$'");
console.log(newStr)
/*解释:"$'"获取的就是str右边的内容,如上正则中"$'"就是" is a good script"。
" is a good language!it$'"会把正则匹配到的"script"替换掉*/
</script>
来自:https://segmentfault.com/a/1190000018173355
我理解的 JavaScript 函数式编程,都认为属于函数式编程的范畴,只要他们是以函数作为主要载体的。
给你的代码增加一点点函数式编程的特性,最近我对函数式编程非常感兴趣。这个概念让我着迷:应用数学来增强抽象性和强制纯粹性,以避免副作用,并实现代码的良好可复用性。同时,函数式编程非常复杂。
Async/await以及它底层promises的应用正在猛烈地冲击着JS的世界。在大多数客户端和JS服务端平台的支持下,回调编程已经成为过去的事情。当然,基于回调的编程很丑陋的。
如果你曾经了解或编写过JavaScript,你可能已经注意到定义函数的方法有两种。即便是对编程语言有更多经验的人也很难理解这些差异。在这篇博客的第一部分,我们将深入探讨函数声明和函数表达式之间的差异。
随着软件应用的复杂度不断上升,为了确保应用稳定且易拓展,代码质量就变的越来越重要。不幸的是,包括我在内的几乎每个开发者在职业生涯中都会面对质量很差的代码。这些代码通常有以下特征:
在js开发中,程序代码是从上而下一条线执行的,但有时候我们需要等待一个操作结束后,再进行下一步操作,这个时候就需要用到回调函数。 在js中,函数也是对象,确切地说:函数是用Function()构造函数创建的Function对象。
这篇文章主要介绍ES5中函数的4种调用,在ES5中函数内容的this指向和调用方法有关。以及ES6中函数的调用,使用箭头函数,其中箭头函数的this是和定义时有关和调用无关。
函数的三种定义方法分别是:函数定义语句、函数直接量表达式和Function()构造函数的方法,下面依次介绍这几种方法具体怎么实现,在实际编程中,Function()构造函数很少用到,前两中定义方法使用比较普遍。
微软 称excel就实现面向开发者的功能,也就是说我们不仅可以全新定义的公式,还可以重新定义excel的内置函数,现在Excel自定义函数增加了使用 JavaScript 编写的支持,下面就简单介绍下如何使用js来编写excel自定义函数。
这篇文章主要讲解:js立即执行函数是什么?js使用立即执行函数有什么作用呢?js立即执行函数的写法有哪些?
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!