《javascript高级程序设计》读书小延伸
这本书已经读了几章了,想着试试能不能做出点东西,就简单的练了把手。觉得对于初学者,自己试着练练,效果还不错的。
挥刀要从轻的开始,起初的原因是和同事谈起曾经的逝水年华(小时候干的坏事)时说起了曾经的一篇课文,讲的是一个小朋友如何巧妙地从1到100累加起来的,猛然间我觉得可以用js算出来,说干就干。
function add(){
for(var i = 1; i <= 100; i ++){
var sum = 0;
sum += i;
}
alert(sum);
}
add();
满心期待的点击运行,正打算欢呼之时,看到结果的那一刻整个人都石化了。结果居然是100,真是奇怪,仔细检查了下代码,发现犯了一个低级的错误,原来把sum声明在循环内了,这就相当于每循环一次,sum都被重新赋值为0,导致叠加变为了 sum = 0 + i ,并不是期望的那样,马虎。改吧,于是乎,把sum声明到了循环体外面,再次运行带到了想要的 5050 。
不过这并不能让我有太多的成就感,我们还可以把它变得更加智能。比如我想从2累加到10,那应该怎么办?想了下,加个参数就好了。
function add(a,b){
var sum = 0;
for(var i = a; i <= b; i ++){
sum += i;
}
alert(sum);//54
}
add(2,10);
在纸上算了算,确实正确。但是这样我只能在代码中进行修改,能不能把它放到界面上,我想让它变得更加有活性,开始值和结束值要按照我的心情来,想让它是多少就是多少,写程序就是要这么任性。
<input type = "text" id = "sum">
<input type = "button" value = "叠加" id = "click">
简单的做了一个文本框和一个点击按钮,期望在文本框中输入不同的数字,然后点击得到累加的结果。
var sum = document.getElementById('sum');
var click = document.getElementById('click');
click.addEventListener('click',function add(){
var number = sum.value.split(",");//将输入的内容转化为数组(默认输入的2个数字用“,”来隔开,比如输入1,3)
var c = 0;
var a = number[0];
var b = number[1];
for(var i = parseInt(a); i <= parseInt(b); i ++){
c +=i;
}
alert(c);
},false);
再写的时候第一想到的是获取到文本框中的字符串,然后再将其转换为数组,通过数组拿到想要的值。如果是空格隔开2个数字的话,可以在用“||”继续添加条件,目前我只能做到特定符号隔开的情况,对于随意输入还没有想到很好的解决办法。对于获得文本框中的的数字,可以在split()中使用正则匹配,比如还是“,”隔开的,改为“/,/”,就可以了。当然也可以用正则进行匹配。
var sum = document.getElementById('sum');
var click = document.getElementById('click');
click.addEventListener('click',function add(){
var pattern = /(\d+),(\d+)/g;
var c = 0;
if(pattern.test(sum.value)){
var a = RegExp.$1;
var b = RegExp.$2;
}
for(var i = parseInt(a); i <= parseInt(b); i ++){
c +=i;
}
alert(c);
},false);
简单的解释下,\d是是匹配的时候查找数字,\d+是匹配至少包含一个数字的字符串,(\d+)是一个捕获组,为了方便进行捕获和赋值。test()函数从字面意思也可看出他是为了检测是否匹配,返回值为true和false,RegExp.$1是获取第一个捕获组,RegExp.$2获取第二个捕获组,这样就很容易得到“,”两边的数字了。
其实无论是用split()还是使用正则,思路是一样的,可能还有更简单的方法,但是目前还没有想到。
这个也可以再继续往下去延伸,比如说我得到这些值后,不去做累加,而是做一些判断条件,就像登录和注册一样。我觉得这样在学习的过程中可以去联想下各种场景,试着写写,不会的就去查,进展可能会快一些。
《javascript高级程序设计》读书小延伸的更多相关文章
- javascript高级程序设计读书笔记-事件(一)
读书笔记,写的很乱 事件处理程序 事件处理程序分为三种: 1.html事件2. DOM0级,3,DOM2级别 没有DOM1 同样的事件 DOM0会顶掉html事件 因为他们都是属性 而 ...
- javascript高级程序设计读书笔记
第2章 在html中使用javascript 一般都会把js引用文件放在</body>前面,而不是放在<head>里, 目的是最后读取js文件以提高网页载入速度. 引用js文 ...
- Javascript高级程序设计读书笔记(第六章)
第6章 面向对象的程序设计 6.2 创建对象 创建某个类的实例,必须使用new操作符调用构造函数会经历以下四个步骤: 创建一个新对象: 将构造函数的作用域赋给新对象: 执行构造函数中的代码: 返回新 ...
- JavaScript高级程序设计-读书笔记(7)
第22章 高级技巧 1.高级函数 (1)安全的类型检测 在任何值上调用Object原生的toString()方法,都会返回一个[object NativeConstructorName]格式的字符串. ...
- javascript高级程序设计 读书笔记2
第五章 引用类型 对象是引用类型的实例,引用类型是一种数据结构,将数据和功能组织在一起.描述的是一类对象所具有的属性和方法.对象是某个特定引用类型的实例,新对象是使用new操作符后跟一个构造函数俩创建 ...
- JavaScript高级程序设计 读书笔记
第一章 JavaScript 简介 第二章 Html中使用JavaScript 第三章 基本概念 第四章 变量,作用域,内存 第五章 引用类型 第六章 面向对象 第七章 函数表达式 第八章 BOM 第 ...
- JavaScript高级程序设计 读书笔记 第一章
JavaScript是一种专门为与网页交互而设计的脚本语言 JavaScript实现 ECMAscript---核心 DOM---文档对象模型 BOM---浏览器对象模型
- Javascript高级程序设计读书笔记(第二章)
第二章 在HTML中使用Javascript 2.1<script>元素 延迟脚本(defer = "defer")表明脚本在执行时不会影响页面的构造,脚本会被延迟到 ...
- JavaScript高级程序设计-读书笔记(6)
第20章 JSON JSON是一个轻量级的数据格式,可以简化表示复杂数据结构的工作量 JSON的语法可以表示一下三种类型的值 l 简单值:使用与JavaScript相同的语法,可以在JS ...
- JavaScript高级程序设计-读书笔记(5)
第13章 事件 1.事件流 事件流描述的是从页面中接收事件的顺序.IE的事件流是事件冒泡流,而Netscape Communicator的事件流是事件捕获流. (1)事件冒泡,即事件开始时由最具体的元 ...
随机推荐
- 配置Mac自带的Apache http服务器
Mac系统是自带Apache,所以很方便我们做一些http测试. 我可以先启动默认的服务器 $ sudo apachectl start 在浏览器打开:http://localhost 将会看到下面信 ...
- 子查询 做where条件 做 from的临时表 ,做select的一个字段 等
子查询 做where条件 做 from的临时表 ,做select的一个字段 等
- SPOJ Repeats(后缀数组+RMQ-ST)
REPEATS - Repeats no tags A string s is called an (k,l)-repeat if s is obtained by concatenating k& ...
- [BZOJ1449] [JSOI2009]球队收益 / [BZOJ2895] 球队预算
Description 在一个篮球联赛里,有n支球队,球队的支出是和他们的胜负场次有关系的,具体来说,第i支球队的赛季总支出是Cix^2+Diy^2,Di<=Ci.(赢得多,给球员的奖金就多嘛) ...
- BZOJ4651/UOJ220 [Noi2016]网格
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- 安徽师大附中%你赛day4T1 金字塔 解题报告
金字塔 题目背景: \(Zdrcl\)带着妹子们来到了胡夫金字塔周边旅游, 发现这里正在进行一个有关金字塔的游戏 题目描述: 游戏规则如下: 1. 这里的金字塔是一个 \(N\) 阶的二维金字塔. 2 ...
- Spring源码解析-AOP简单分析
AOP称为面向切面编程,在程序开发中主要用来解决一些系统层面上的问题,比如日志,事务,权限等等,不需要去修改业务相关的代码. 对于这部分内容,同样采用一个简单的例子和源码来说明. 接口 public ...
- Clevo P950笔记本加装4G模块
要补全的电路部分如下(原理图见附件) 这里经过尝试,发现左上角R217,R218不用接,3G_POWER部分不接(包括MTS3572G6.UK3018及电阻电容,3G_PWR_EN实测是3.3V,驱动 ...
- [bzoj 1143]最长反链二分图最大匹配
Dilworth定理:偏序集能划分成的最少的全序集的个数与最大反链的元素个数相等. 证明:http://www.cnblogs.com/itlqs/p/6636222.html 题目让求的是最大反链的 ...
- 使用 FirewallD 构建动态防火墙
使用 FirewallD 构建动态防火墙 FirewallD 提供了支持网络/防火墙区域(zone)定义网络链接以及接口安全等级的动态防火墙管理工具.它支持 IPv4, IPv6 防火墙设置以及以太网 ...