JavaScript学习要点
Javascript相关内容
1.序列化--json
- stringify() 将对象转换为字符串
- parse() 将字符串转换为对象
list=[11,22,33,44,55];
结果:(5) [11, 22, 33, 44, 55]
str=JSON.stringify(list);
结果:"[11,22,33,44,55]"
list1=JSON.parse(str);
结果:(5) [11, 22, 33, 44, 55]
2.字符串转义--encodeURI
- encodeURI(url);
- decodeURI(url);
- decodeURIComponent(url) ;
- encodeURIComponent(url);
url="https://www.sogou.com/web?query=土味程序员";
转义结果:"https://www.sogou.com/web?query=土味程序员"
changeStr=encodeURI(url);
转义结果:"https://www.sogou.com/web?query=%E7%8E%8B%E6%98%9F%E4%BC%9F"
changeStr1=encodeURIComponent(url);
转义结果:"https%3A%2F%2Fwww.sogou.com%2Fweb%3Fquery%3D%E7%8E%8B%E6%98%9F%E4%BC%9F"
decodeURI(changeStr);
转义结果:"https://www.sogou.com/web?query=土味程序员"
decodeURIComponent(changeStr1);
转义结果:"https://www.sogou.com/web?query=土味程序员
小知识:通常登入界面,第一次登入后,后面就不需要再次登入,可以直接访问,。原理:客户端连接后,服务器会下发一串**********给客户端,客户端将**********通过转义
后保存在cookie中,仅供博主自己参考。
3.eval
eval方法只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。因此请不要为 eval() 函数传递 String 对象来作为参数。
如果试图覆盖 eval 属性或把 eval() 方法赋予另一个属性,并通过该属性调用它,则 ECMAScript 实现允许抛出一个 EvalError 异常。(引用百度说明)
话不多说直接上例子:
num = eval("2+2");
输出:4
var x=4;
num=eval("x+4");
输出:8
python:函数eval(表达式);
函数exec(执行代码);
javascript:eval中既可以是函数也可以是表达式;
4.时间
- Date()函数
var time=new Date();//变量声明时需要使用new关键字
time.getDate();//获取当前日期
time.getDay();//当前是星期几
time.getYear();//获取当前的年 time.setDate(n);
time.setDay(n);
time.setYear(n);
Date的相关函数:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
5.作用域
其他语言的作用域 ==》代码块;
python的作用域 ==》 函数;
JavaScript的作用域 ==》函数;
要点:
- JavaScript以函数为作用域。
- 函数的作用域在函数未被调用之前已经建立。
- 函数的作用域在作用域链中,并且也是在调用之前建立。
- 函数内的局部变量提前声明。
name="tuwei";
function func(){
var name = "tuwei1";
function inner(){
console.log(name);
}
retuen inner;
}
var ref = func();
ref();
//打印"tuwei1" ;
遇到作用域问题严格按照上述4点来判断。
function func(){
console.log(name);
var name="tuwei";
}
func();
//程序打印undefine;
1.var xxoo=undefine;
2.console.log(name);
3.var xxoo="tuwei";
6.面向对象
function Foo(name){
this.name=name;
this.sayName=function(){
console.log(this.name);
}
}
var obj = new Foo("程序员");
console.log(obj.name);
obj.sayName;
var obj1 = new Foo("程序员1");
console.log(obj1.name);
obj1.sayName;
此处代码运行有问题:1.只打印了obj.name和obj1.name两个参数(尚未明白)。
2.每个对象都会申请一个sayName函数,这样会占用大量空间(是否有方法解决此问题)。
为了解决问题2:javascript引入了原型。
请看代码分析:
function Foo(name){
this.name=name;
}
//原型
Foo.prototype={
// body...
'sayName':function(){
console.log(this.name);
}
};
var obj = new Foo("程序员");
console.log(obj.name);
obj.sayName;
var obj1 = new Foo("程序员1");
console.log(obj1.name);
obj1.sayName;
原型的概念类似于python中的class类方法,会将所有对象的相同方法统一存放于某个地区,方便对象的调用。
格式如上述代码所示。
JavaScript学习要点的更多相关文章
- Java程序猿JavaScript学习笔记(2——复制和继承财产)
计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...
- JavaScript学习(一) —— 环境搭建与JavaScript初探
1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...
- Web编程基础--HTML、CSS、JavaScript 学习之课程作业“仿360极速浏览器新标签页”
Web编程基础--HTML.CSS.JavaScript 学习之课程作业"仿360极速浏览器新标签页" 背景: 作为一个中专网站建设出身,之前总是做静态的HTML+CSS+DIV没 ...
- 【C#】第3章学习要点(一)--整体把握
分类:C#.VS2015 创建日期:2016-06-18 使用教材:(十二五国家级规划教材)<C#程序设计及应用教程>(第3版) 一.使用别人已经设计好的类简化你的代码编写工作量 当让你去 ...
- JavaScript学习(3):函数式编程
在这篇文章里,我们讨论函数式编程. 什么是函数式编程?根据百度百科的描述,“函数式编程是种编程典范,它将电脑运算视为函数的计算.函数编程语言最重要的基础是 λ 演算(lambda calculus). ...
- JavaScript学习(2):对象、集合以及错误处理
在这篇文章里,我们讨论一下JavaScript中的对象.数组以及错误处理. 1. 对象 对象是JavaScript中的一种基本类型,它内部包含一些属性,我们可以对这些属性进行增删操作. 1.1 属性 ...
- JavaScript学习13 JavaScript中的继承
JavaScript学习13 JavaScript中的继承 继承第一种方式:对象冒充 <script type="text/javascript"> //继承第一种方式 ...
- JavaScript学习12 JS中定义对象的几种方式
JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...
- JavaScript学习11 数组排序实例
JavaScript学习11 数组排序实例 数组声明 关于数组对象的声明,以前说过:http://www.cnblogs.com/mengdd/p/3680649.html 数组声明的一种方式: va ...
随机推荐
- (动态)代理于HOOK的区别于关系
代理模式是MITM中间人攻击模式: 是拦截对象的所有交互,然后进行处理转发: HOOK模式是定点拦截,只针对单个函数做处理转发: HOOK模式可以在动态代理模式基础上实现:因为代理模式拦截所有.
- Python 3 与 Javascript escape 传输确保数据正确方法和中文乱码解决方案
注意:现在已不推荐 escape 函数,推荐使用 encodeURIComponent 函数,其中方法更简单,只需进行URL解码即可. 当然了,如下文章解决方案一样可行. 前几天用Python的Bo ...
- CF613D:Kingdom and its Cities(树形DP,虚树)
Description 一个王国有n座城市,城市之间由n-1条道路相连,形成一个树结构,国王决定将一些城市设为重要城市. 这个国家有的时候会遭受外敌入侵,重要城市由于加强了防护,一定不会被占领.而非重 ...
- 「GXOI / GZOI2019」旅行者
题目 我还是太傻了 考虑每一条边的贡献,对于一条有向边\((u,v,w)\),我们求出\(k\)个关键点中到\(u\)最近的距离\(dis_1\),以及\(v\)到\(k\)个关键点中最近的距离\(d ...
- HBase学习之路 (二)HBase集群安装
前提 1.HBase 依赖于 HDFS 做底层的数据存储 2.HBase 依赖于 MapReduce 做数据计算 3.HBase 依赖于 ZooKeeper 做服务协调 4.HBase源码是java编 ...
- Java基础加强之并发(四)synchronized关键字
并发系列参考文章http://www.cnblogs.com/skywang12345/p/3323085.html#3907193 synchronized原理 在java中,每一个对象有且仅有一个 ...
- jdk8中tomcat修改配置PermSize为MetaspaceSize 标签: tomcatPermSizeMetaspaceSize
JDK8中用metaspace代替permsize,因此在许多我们设置permsize大小的地方同样需要修改配置为metaspace 将-XX:PermSize=200m;-XX:MaxPermSiz ...
- SQLSERVER 数据类型int、bigint、smallint 和 tinyint范围
[bigint] 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字).存储大小为 8 个字节. [int ...
- 清除浮动元素的margin-top失效原因(更改之前的错误)
//样式代码body,div{ margin:; padding:; } .box1{ background:#900; width:200px; height:200px; margin:20px ...
- linux查看磁盘占用情况
一:首先是先登录 二:查看当前目录 命令:df -h 三:查看具体文件夹占用情况 命令:du --max-depth=1 -h /data/ 或者:为了快算显示,同时也只是想查看目录整体占用大小 命 ...