1. 字符串处理常常用在处理服务器回传的数据、动态拼接生成html等,是前端面试的必考题。

  2. 我觉得字符串处理这种常用到的,一定要了然于心,不然用到时急急忙忙去翻手册费半天。


入正题,首先提出平常遇到的几个需求,后面我们来一步一步解决它:

需求1:根据服务器返回的json数据,动态添加元素到列表<ul>    【难度:1】

使用场景:瀑布流下拉刷新、延迟加载、ajax点击加载列表

html模板是这样:

<ul class="icon_list">
<li><a href="#"><img src="data:images/floor1-1.png" alt=""></a>
<p>360杀毒</p>
<p>10.00M</p>
<a href="">下载</a></li>
<li><a href="#"><img src="data:images/floor1-2.png" alt=""></a>
<p>软件管家</p>
<p>10.00M</p>
<a href="">下载</a></li>
</ul>

json是这样:

{softList:[
{"name":"360杀毒","size":"10.00M","png_src":"/floor1-1.png","href":"www.baidu.com"},
{"name":"软件管家","size":"12.00M","png_src":"/floor1-2.png","href":"www.baidu.com"},
{"name":"360浏览器","size":"14.00M","png_src":"/floor1-3.png","href":"www.baidu.com"},
{"name":"360商场","size":"10.20M","png_src":"/floor1-4.png","href":"www.baidu.com"},
{"name":"影视大全","size":"11.00M","png_src":"/floor1-5.png","href":"www.baidu.com"},
{"name":"万能省电","size":"13.00M","png_src":"/floor1-6.png","href":"www.baidu.com"},
{"name":"360wifi","size":"25.10M","png_src":"/floor1-7.png","href":"www.baidu.com"},
{"name":"360ROOT","size":"10.90M","png_src":"/floor1-8.png","href":"www.baidu.com"},
]}

结果是这样:

解决思路:将动态生成各个<li>拼接成字符串,追加到父节点的innerHTML里面

下面给出直接可运行的页面代码(本文太长的代码都会默认折叠了一下):

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
<title>page name</title>
<style>
/*超链接去下划线*/
a {
display: block;
overflow: hidden;
outline: none;
text-decoration: none;
color: black;
font-family: "Microsoft YaHei UI";
color: #333;
}
/*li去掉点号*/
li {
list-style-type: none;
text-align: center;
}
.floor h2 {
font-size: 1.6em;
margin-top: 10px;
margin-left: 4%;
color: #333333;
}
/*响应式布局核心css*/
.floor .icon_list{
min-width: 320px;
display: flex;
flex-direction: row;
flex-wrap: wrap;
justify-content: flex-start;
} .floor .icon_list li {
width: 25%;
margin-bottom: 15px;
} .floor .icon_list li img {
width: 60%;
} .floor .icon_list li p {
margin: 4px;
font-size: 15px;
color: #33333f;
} .floor .icon_list li p:nth-child(3) {
color: #ccc;
font-size: 14px;
} .floor .icon_list li a:last-child {
margin: 5px auto 0;
width: 66%;
height: 25px;
border: none;
line-height: 27px;
border-radius: 18px;
background: #def3e1;
font-size: 14px;
color: #23ac38;
} </style>
</head> <body> <!--手机软件-->
<div class="content">
<div class="floor">
<h2>手机软件</h2>
<ul class="icon_list" id="softList">
</ul>
</div>
</div>
</div>
</body>
<script>
//json可以通过ajax加载进来
var json = {
softList: [
{"name": "360杀毒", "size": "10.00M", "png_src": "/floor1-1.png", "href": "www.baidu.com"},
{"name": "软件管家", "size": "12.00M", "png_src": "/floor1-2.png", "href": "www.baidu.com"},
{"name": "360浏览器", "size": "14.00M", "png_src": "/floor1-3.png", "href": "www.baidu.com"},
{"name": "360商场", "size": "10.20M", "png_src": "/floor1-4.png", "href": "www.baidu.com"},
{"name": "影视大全", "size": "11.00M", "png_src": "/floor1-5.png", "href": "www.baidu.com"},
{"name": "万能省电", "size": "13.00M", "png_src": "/floor1-6.png", "href": "www.baidu.com"},
{"name": "360wifi", "size": "25.10M", "png_src": "/floor1-7.png", "href": "www.baidu.com"},
{"name": "360ROOT", "size": "10.90M", "png_src": "/floor1-8.png", "href": "www.baidu.com"}, ]
}
//动态添加’手机软件 处的列表元素
function addSoftList(softList) {
//a要使用getElementById,如果使用getElementsByClassName注意要加[0]
var a = document.getElementById('softList');
//var a = document.getElementsByClassName('icon_list')[0];
var str = '';
//一条li的格式
/*<li><a href="#"><img src="data:images/floor1-1.png" alt=""></a>
<p>360杀毒</p>
<p>10.00M</p>
<a href="">下载</a></li>*/
for (var i in softList) {
str += '<li><a href="#"><img src="data:images' + softList[i].png_src + '" alt=""></a>' +
'<p>' + softList[i].name + '</p>' +
'<p>' + softList[i].size + '</p>' +
'<a href="' + softList[i].href + '">下载</a></li>';
}
//追加元素
a.innerHTML += str;
};
//这样调用
addSoftList(json.softList);
</script>
</html>

展开代码

顺便也做成了Flex响应式布局,无论页面是什么尺寸都会自动适应页面大小。

不明白什么是Flex响应式布局的可参见 http://www.cnblogs.com/chris-oil/p/5831028.html

需求2:生成驼峰法字符串    【难度:1】

例如:border-bottom-color->borderBottomColor

解决思路:将字符串按单词切分->将每个子字符串首字母大写->合成新字符串(分别用到split函数、toUpperCase函数、join函数)

var str='border-bottom-color';
String.prototype.transform = function(){
var arr = this.split('-'); //切分单词,存到数组
var _length=arr.length;
for(var i=1;i<_length;i++){
arr[i]=arr[i].charAt(0).toUpperCase()+arr[i].substring(1);
//首字母大写
}
return arr.join('') ;//合并数组到字符串
}
alert(str.transform());

展开代码

前端JS常用字符串处理实例的更多相关文章

  1. JS常用字符串处理方法应用总结

    这篇文章主要总结了JS常用字符串的处理方法,需要的朋友可以参考下   1.indexOf()方法,从前往后查找字符串位置,大小写敏感,从0开始计数.同理,lastIndexOf() 方法从后往前,两个 ...

  2. JS截取字符串方法实例

    // JS截取字符串可使用 substring()或者slice() // // 函数:substring() // 定义:substring(start,end)表示从start到end之间的字符串 ...

  3. 前端js常用正则表达式实例讲解

    本文内容整理自他人优秀的博客,非纯原创.仅借此学习和整理. 1.匹配用户名 规则描述: 长度4-6位: {4,16} 字母: [a-z] [A-Z] 数字: [0-9] 下划线: [_] 减号: [- ...

  4. 前端js实现字符串/图片/excel文件下载

    在web开发中,如果你想让用户下载或者导出一个文件,应该怎么做呢?传统的做法是在后端存储或者即时生成一个文件来提供下载功能,这样的优势是可以做权限控制.数据二次处理,但缺点是需要额外发起请求.增大服务 ...

  5. JS 常用字符串操作

    Js字符串操作函数大全 /*******************************************                        字符串函数扩充              ...

  6. js常用字符串处理方法

    JS自带函数concat将两个或多个字符的文本组合起来,返回一个新的字符串.var a = "hello";var b = ",world";var c = a ...

  7. js常用字符串函数

    // JS字符串 //1.replace字符串替换,只能换第一部分,就是说多个字符相同,只能换下最先的 var str='helloworld!'; alert(str.replace('llo',' ...

  8. Js 常用字符串操作 API

    常用的一些字符串操作 API 整理 1.str.charAt(index).str.charCodeAt(index) - 返回指定位置的字符 / 字符编码(0~65535) index - 必须,表 ...

  9. JS 常用字符串,数组操作

    JavaScript String/Array对象 JS String对象   String 对象属性 属性 描述 constructor 对创建该对象的函数的引用 length 字符串的长度 pro ...

随机推荐

  1. 浅谈javascript面向对象

    我们常用的两种编程模式 POP--面向过程编程(Process-oriented programming) 面向过程编程是以功能为中心来进行思考和组织的一种编程方法,它强调的是系统的数据被加工和处理的 ...

  2. navicat注册码

    1. navicat for mysql 9 注册码   :::   NAVL-EHNC-7N7P-W6GM  2. navicat for mysql 9.17中文版 注册码 :: NAVM-5ZC ...

  3. java使用tomcat7的maven插件发布到服务器

    服务器容器使用tomcat7的maven插件,使用该插件不需要使用tomcat服务器.以下示例均以paycore项目为例. 一.使用tomcat7-maven-plugin 首先在主pom(payco ...

  4. Markdown

    1. 斜体和粗体 代码: *斜体*或_斜体_ **粗体** ***加粗斜体*** ~~删除线~~ 显示效果: 这是一段斜体 这是一段粗体 这是一段加粗斜体 这是一段删除线 2. 分级标题 第一种写法: ...

  5. 并发包的线程池第一篇--ThreadPoolExecutor执行逻辑

    学习这个很长时间了一直没有去做个总结,现在大致总结一下并发包的线程池. 首先,任何代码都是解决问题的,线程池解决什么问题? 如果我们不用线程池,每次需要跑一个线程的时候自己new一个,会导致几个问题: ...

  6. jquery的几种ajax提交方式

    $.post( url, function(data){ if(data.retcode == "0"){ alert(data.retmsg); }else{ alert(dat ...

  7. 利用animation和text-shadow纯CSS实现loading点点点的效果

    经常在网上看到loading状态时的点点点的动态效果,自己也用JS写了一个,思路是使用一个计数参数,然后在需要添加点的元素后面利用setInterval一个一个加点,当计数到3时,把点变为一个--写完 ...

  8. JavaScript系列文章:变量提升和函数提升

    第一篇文章中提到了变量的提升,所以今天就来介绍一下变量提升和函数提升.这个知识点可谓是老生常谈了,不过其中有些细节方面博主很想借此机会,好好总结一下. 今天主要介绍以下几点: 1. 变量提升 2. 函 ...

  9. Caffe学习

    将binaryproto转为npy import caffe % suppose caffe is already in the path of Python import numpy as np i ...

  10. redis 在后台启动

    昨天在cmd窗口启动,窗口关闭,再次访问会报错,所以在次打开 首先你要安装服务:redis-server --service-install redis.windows.conf --loglevel ...