javascript练习题(3):基础字符串运算
用两种方法实现下列问题!
1. 把一个字符串转化为驼峰写法
需求:margin-left=>marginLeft
思路一:split
把它转化为一个数组然后修改内容
function convertStr(str){
var arr=str.split('-');
arr=arr.map(function(item){
return item[0].toString().toUpperCase()+item.slice(1);
});
var newStr=arr.join('');
newStr=newStr[0].toLowerCase()+newStr.slice(1);
//console.log(newStr);
return newStr;
}
convertStr('border-left-color');//borderLeftColor
思路二:暴力拆解
强行用循环暴力拆解
function convertStr(str){
var newStr='';
for(var i=0;i<str.length;i++){
if(str[i]!=='-'){
if(str[i-1]&&str[i-1]=='-'){
newStr+='';
}else{
newStr+=str[i];
}
}else{
newStr+=str[i+1].toUpperCase();
}
}
//console.log(newStr);
return newStr;
}
convertStr('border-left-color');
思路三:正则
function convertStr(str){
var re=/-(\w)/g;//匹配横杠下的全部字符比如-b,-c
return str.replace(re,function($0,$1){
//$0表示整个字符串,$1表示正则内第一个括号的内容
return $1.toUpperCase();
});
}
console.log(convertStr('border-left-color'))
正则的题目出不完,所以死记是没有用的。
2. 查找字符串出现最多的字符和个数
思路一 :暴力拆解(对象)
不如构造一个对象?
var a='isfaogjaa;fgagp[;jhbsolbsdfgbvsdfbdbd]';
function findMost(str){
var type={};
for(var i=0;i<str.length;i++){
if(type.hasOwnProperty(str[i])){
type[str[i]]+=1;
}else{
type[str[i]]=1;
}
}
type.getMost=['',0];
for(attr in type){
if(type[attr]>type.getMost[1]){
type.getMost=[attr,type[attr]];
}
}
//console.log(type.getMost[0]);
return type.getMost;
}
findMost(a);//“b”
通过对象进行判断。
思路二:正则
把字符串转为数组,进行排序。
不必指定任何规则,因为已经排列好了。
var a='isfaogjaa;fgagp[;jhbsolbsdfgbvsdfbdbd]';
function findMost(str){
var arr=str.split('');
arr.sort();
str=arr.join('');
var re=/(\w)\1+/g;
//表示重复1次的部分。
var num=0;
var value='';
str.replace(re,function($0,$1){
//console.log($0)//aaa,bbb,。。。就像一个循环
if(num<$0.length){
num=$0.length;
value=$1;
}
});
console.log([num,value]);
return [num,value];
}
findMost(a);//“b”
3. 给数字加千分符
比如:10000=>10,000
转化之后显然是一个字符串。
思路一:暴力拆解
这个拆解已经很暴力了。
var a=8752317;
function changeNum(num){
var arr=num.toString().split('');
var newArr=[];
var head=num.toString().length%3;
arr=arr.slice(head)
for(var i=0;i<arr.length;i+=3){
newArr.push(arr.slice(i,i+3).join().replace(/,/g,''));
}
var newStr='';
if(num.toString().slice(0,head)){
newStr=num.toString().slice(0,head)+','+newArr.toString();
}
console.log(newStr);
return arr;
}
changeNum(a);
思路二:正则
实话说正则很难。要匹配位置,要从后匹配
(?=)前项声明
(?!)反前项声明
比如/a(?=b)/g
表示匹配的是字符串出现"ab"时,其中的a。反之,/a(?!b)/g
匹配的是所有不为ab字符串中的a如果你不写前面的a,那么这个前项声明就是匹配位置。
var a=8752317;
function changeNum(num){
var re=/(?=(\d{3})+$)/g;
//匹配规则:重复出现三次都是数字,最少一次,从后面开始($)
return num.toString().replace(re,',')
}
console.log(changeNum(a));
结果又有bug比如752317,转化结果是,752,317
。
所以还得用反前项声明匹配边界。
var re=/(?=(?!\b)(\d{3})+$)/g;
4. 返回一个只包含数字类型的数组
比如afjasoeigjs123sgdhedhhe456osddhnofd789
=>[123,456,789]
思路一:暴力拆解
var a='afjasoeigjs123sgdh1edhhe456osddhnofd789';
function change(str){
var arr=[];
for(var i=0;i<str.length;i++){
if(Number(str[i])){
if(str[i-1]&&Number(str[i-1])){
arr.push(str[i])
}else{
arr.push('\/');
arr.push(str[i]);
}
}
}
arr=arr.join().replace(/,/g,'').split('\/');
arr=arr.filter(function(a){
return a!=false;
});
return arr
}
console.log(change(a));
暴力拆解不是没有价值。在某些极端环境下,或许可以提供了某种思路。
思路二:正则
var a='afjasoeigjs123sgdh1edhhe456osddhnofd789';
function change(str){
var re=/\d+/g;
return str.match(re);
}
console.log(change(a));
javascript练习题(3):基础字符串运算的更多相关文章
- JavaScript框架设计(四) 字符串选择器(选择器模块结束)
JavaScript框架设计(四) 字符串选择器(选择器模块结束) 经过前面JavaScript框架设计(三) push兼容性和选择器上下文的铺垫,实现了在某一元素下寻找,现在终于进入了字符串选择器 ...
- JavaScript中常见的字符串操作函数及用法
JavaScript中常见的字符串操作函数及用法 最近几次参加前端实习生招聘的笔试,发现很多笔试题都会考到字符串的处理,比方说去哪儿网笔试题.淘宝的笔试题等.如果你经常参加笔试或者也是一个过来人,相信 ...
- Java与JavaScript中判断两字符串是否相等的区别
JavaScript是一种常用的脚本语言,这也决定了其相对于其他编程语言显得并不是很规范.在JavaScript中判断两字符串是否相等 直接用==,这与C++里的String类一样.而Java里的等号 ...
- JavaScript 的一些基础知识
JavaScript基本语法 调试 打开 Chrome 开发工具 Win F12 Mac Command + Option + I 输入代码.测试执行 var str = 'evenyao' cons ...
- javascript之正则表达式基础知识小结
javascript之正则表达式基础知识小结,对于学习正则表达式的朋友是个不错的基础入门资料. 元字符 ^ $ . * + ? = ! : | \ / ( ) [ ] { } 在使用这些符号时需要 ...
- php面试专题---12、JavaScript和jQuery基础考点
php面试专题---12.JavaScript和jQuery基础考点 一.总结 一句话总结: 比较常考察的是JavaScript的HTML样式操作以及jQuery的选择器和事件.样式操作. 1.下列不 ...
- 100多个很有用的JavaScript函数以及基础写法大集合
100多个很有用的JavaScript函数以及基础写法大集合 1.document.write("");为 输出语句2.JS中的注释为//3.传统的HTML文档顺序是:docume ...
- JS获取url中query_str JavaScript RegExp 正则表达式基础详谈
面我们举例一个URL,然后获得它的各个组成部分:http://i.cnblogs.com/EditPosts.aspx?opt=1 1.window.location.href(设置或获取整个 URL ...
- JavaScript中,提取子字符串方法:Slice、Substring、Substr的比较。
在JavaScript中,提取子字符串主要是通过 Slice.Substring.Substr 三个方法之一. // slice // 语法: string.slice(beginSlice [, e ...
随机推荐
- 题注Oracle数据库的网络连接原理
版权声明:本文博客原创文章,博客,未经同意,不得转载.
- JavaScipt中对DOM的理解
一.理解DOM 浏览器通过文档对象模型DOM使JavaScript程序可以访问页面上的元素,而DOM是页面上XHTML中文档正文标题.段落.列表.样式ID.class以及所有其他出现的数据的一个内部表 ...
- 使用Flexible实现手淘H5页面的终端适配(转)
曾几何时为了兼容IE低版本浏览器而头痛,以为到Mobile时代可以跟这些麻烦说拜拜.可没想到到了移动时代,为了处理各终端的适配而乱了手脚.对于混迹各社区的偶,时常发现大家拿手机淘宝的H5页面做讨论—— ...
- 将Model实体类对象作为WebService接口参数(转)
转自:http://www.cnblogs.com/fengyishou/archive/2009/02/27/1399281.html 关于web服务的有关基础知识,看了基本书,但是不敢在这里乱说, ...
- WinForm窗体淡入效果界面的简单实现方法
WinForm窗体淡入效果主要使用到控件的Opacity属性 首先在WinForm窗体中拖入一个Timer控件,然后再Timer控件的Tick事件添加如下代码: private void timer1 ...
- struts2 <s: select 标签值
JSP页面: <s:select label="家长导航" value="id" name="navson.pid" list=&q ...
- WinFrom打开一个窗体关闭另一个窗体
在写Winform程序的时候,经常会遇到“打开一个新的窗体然后关闭本窗体”之类的问题.最常见的就是登陆界面和主窗体了.而最常见的处理方法就是表单判断正确后 new MainForm().Show(); ...
- oracle读写文件--利用utl_file包对磁盘文件的读写操作
oracle读写文件--利用utl_file包对磁盘文件的读写操作 摘要: 用户提出一个需求,即ORACLE中的一个表存储了照片信息,字段类型为BLOB,要求能导出成文件形式. 本想写个C#程序来做, ...
- ORACLE抽象数据类型
ORACLE抽象数据类型 *抽象数据类型*/1,抽象数据类型 概念包含一个或多个子类型的数据类型不局限于ORACLE的标准数据类型可以用于其他数据类型中 2,创建抽象数据类型 的语法(必须用NOT F ...
- Ali也开始玩了阿
http://blog.alipay.com/ 查看源代码