JavaScript学习总结(八)
这一节结束,我们的JavaScript学习总结系列文章第一阶段就要结束了,今后会适当的补充一些高级的内容,敬请期待。
好了,废话不说进入这一节的学习。
联动框
联动框,实在是太常见了。比如淘宝,我们选择地址的时候,选择了省份,淘宝就会自动列出来城市乡道的信息,这一小节我们要做的就是这个。
城市联动框
<head>
<meta charset="utf-8">
<title>联动框</title>
</head>
<script type="text/javascript">
function showCity(){
//维护一个二维数组,选择河北以及这几个城市是有原因滴。。。广西不太了解,瞎写的。。。
var citys = [[],["承德","廊坊","邯郸"],["广州","佛山","中山"],["a","b","c"],["海淀","朝阳","顺义"]];
//获取省份对应的节点
var provinceNode = document.getElementById("province");
//alert(provinceNode.selectedIndex);
//获取对应的城市
var cityDatas = citys[provinceNode.selectedIndex];
//找到city节点
var cityNode = document.getElementById("city");
//先清空city中的所有option,删除的时候要注意,不能使用直接遍历的方式删除,
//可能会导致元素删不完全,我们可以每次只删除第一个元素,还有一种是直接设置options的个数即可,这种不做介绍
var children = cityNode.childNodes;
for(var i = 0; i<children.length ; ){
cityNode.removeChild(children[i]);
}
//向select添加元素即可
for(var i=0;i<cityDatas.length;i++){
var optionNode = document.createElement("option");
optionNode.innerHTML = cityDatas[i];
cityNode.appendChild(optionNode);
}
}
</script>
<body>
省份<select onChange="showCity()" id="province">
<option>省份</option>
<option>河北</option>
<option>广东</option>
<option>广西</option>
<option>北京</option>
</select>
城市<select id="city">
<option>城市</option>
</select>
</body>
操作元素的CSS样式
JavaScript除了能够操作标签元素之外,同样能够操作元素的CSS样式,以达到改变元素样式的作用。
下面我们的这个例子大家应该十分的熟悉,那就是验证码的生成。我们生成一个验证码,以达到操作验证码样式的作用。
<script type="text/javascript">
function createCode(){
//验证码数据
var datas = ["5","好","人","德","和","B","@","是","静","你"];
//验证码字符串,产生索引值
var code = "";
for(var i=0;i<4;i++){
var index = Math.floor(Math.random()*datas.length);
//得到字符串
code += datas[index];
}
var codeNode = document.getElementById("code");
codeNode.innerHTML = code;
//CSS样式的操作就是通过style实现的
codeNode.style.fontSize ="24px";
codeNode.style.color = "yellow";
codeNode.style.backgroundColor="red";
codeNode.style.textDecoration = "line-through";
}
function ready(){
createCode();
}
</script>
<body onLoad="ready()">
<span id="code"></span><a href="#" onClick="createCode()">看不清,换一个</a>
</body>
这就是一个验证码的简单实现方式,同时我们也他弄过了style属性来设置了CSS样式。
正则表达式
同样的,正则表达式同样也是一个对象,而创建正则表达式的方式共有两种。
方式1:
/正则表达式/模式
//java中的正则表达式是写在“”中的,不过js的正则用法和java中基本一致
方式2:
new RegExp("正则表达式",模式);
正则表达式的常用方法:
test() 使用正则对象去匹配字符串 如果匹配成功返回ture,否则返回false
exec() 根据正则表达式去查找字符串符合规则的内容
注意,JavaScript中的正则表达式十分的恶心,在正则表达式中没有边界匹配器的情况下,字符串只要能匹配到正则中的一部分,test就会返回true,所以加入边界匹配器是十分重要的 (^开始字符——$结束字符)。
一个简单的test()例子:
var str = "helloworld12345";
var reg = /^[a-z0-9]+$/;
alert("匹配吗?"+reg.test(str));//true
那么什么是模式呢?模式可以理解为搜索的条件,加在模式位置就可以了。
g (全文查找出现的所有 pattern) 如果不加全文搜索模式,那么每次找到所要的内容,就会返回字符串开头重新找,然后电脑就炸了。
i (忽略大小写)
下面是一个exec()的例子:
//查找出三个字符组成的单词。
var str ="hao hao xue xi tian tain xiang shang;
var reg = /\b[a-z]{3}\b/gi;
var line ="";
while((line = reg.exec(str))!=null){
document.write(line+"<br/>")
}
JavaScript学习总结(八)的更多相关文章
- JavaScript学习笔记八
本文依据慕课网课程<JavaScript进阶>学习整理 第8章 浏览器对象 8-1 window对象 window对象是BOM的核心.window对象指当前的浏览器窗体. wind ...
- JavaScript学习总结(八)——JavaScript数组
JavaScript中的Array对象就是数组,首先是一个动态数组,无需预先制定大小,而且是一个像Java中数组.ArrayList.Hashtable等的超强综合体. 一.数组的声明 常规方式声明: ...
- JavaScript学习 - 基础(八) - DOM 节点 添加/删除/修改/属性值操作
html代码: <!--添加/删除/修改 --> <div id="a1"> <button id="a2" onclick=&q ...
- JavaScript学习(八)
- javascript学习笔记(四) Number 数字类型
数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数 toExponential() 方法 用科学 ...
- JavaScript学习总结——转
JavaScript学习总结(一)——JavaScript基础 JavaScript学习总结(二)——逻辑Not运算符详解 JavaScript学习总结(三)——逻辑And运算符详解 JavaScri ...
- JavaScript学习基础部分
JavaScript学习基础 一.简介 1.JavaScript 是因特网上最流行的脚本语言,并且可在所有主要的浏览器中运行,比方说 Internet Explorer. Mozilla.Firefo ...
- javascript学习的思维导图
今天逛师父的博客园,发现了好东西~~~~我给偷过来了~~~那就是javascript学习的思维导图,比自己整理更快速. 思维导图小tips: 思维导图又叫心智图,是表达发射性思维的有效的图形思维工具 ...
- JavaScript学习——使用JS完成页面定时弹出广告
1.获取图片的位置(document.getElementById(“”)) 隐藏图片:display:none 定时操作:setInterval(“显示图片的函数”,3000); 2.步骤分析 ( ...
随机推荐
- UVA - 1346 Songs (贪心+排序)
题意:已知每首歌的标号,长度和播放频率,求一种播放顺序,使得最小,并且输出该播放顺序下第t首歌的标号. 分析: 1.长度越短,播放频率越大的歌排在前面,上式越小. 2.s(i)表示的是当前播放顺序下这 ...
- ES6 之 Proxy
概述 Proxy 用于修改某些操作的默认行为,等同于在语言层面做出修改. Proxy 可以理解在目标对象架设一个“拦截”层外界对该对象的访问都必须先通过这层拦截,因此提供了一种机制可以对外界的访问进行 ...
- C# ------ MEF
参考 参考 MEF全称Managed Extensibility Framework, 是一个用于创建可扩展的轻型应用程序的库.开发人员可以利用MEF发现并使用扩展,但并不需要配置,而且还可以在应用程 ...
- Spark 内存管理
Spark 内存管理 Spark 执行应用程序时, 会启动 Driver 和 Executor 两种 JVM 进程 Driver 负责创建 SparkContext 上下文, 提交任务, task的分 ...
- Apache NiFi Processor实战
1 前言 Apache NiFi是什么?NiFi官网给出如下解释:“一个易用.强大.可靠的数据处理与分发系统”.通俗的来说,即Apache NiFi 是一个易于使用.功能强大而且可靠的数据处理和分发系 ...
- MyBatis 关联查询的实现:一对多
有2个实体:用户.订单,一个用户可以拥有多个订单,同时这多个订单属于一个用户,即一对多. user_tb: order_tb: 在“多”的一方(order)添加“一”的一方(user)的主键(user ...
- UE手游如何应对CPU帧率瓶颈和卡顿?
如何高效准确详细的对性能进行剖析?腾讯游戏学院专家Leonn将归纳总结在UE下对每一性能指标的剖析方法,本文重点讲解如何应对CPU帧率瓶颈和卡顿? CPU上帧率低和卡顿是性能优化中最易出现的一部分,尤 ...
- linux下的hashpump安装及使用
hashpump是linux上的一个进行hash长度拓展攻击的工具,安装过程如下: git clone https://github.com/bwall/HashPump apt-get instal ...
- Android自定义View——仿滴滴出行十大司机评选活动说明
滴滴出行原版图 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 仿图 ? ? ? ? ? ? 1.分 ...
- StringBuffer和StringBuilder类
对字符串进行修改的时候,需要使用StringBuffer和StringBuilder类(String类是不可改变的,一旦创建了String对象,那它的值就无法改变了). 和String类不同的是,St ...