JavaScript 基础篇(一)


Posted in Javascript onMarch 30, 2012

JavaScript 基础篇(一)
基础篇
Javascript:一、数据类型和值
javascript:允许使用3种基本类型数据--------数字、字符串、布尔值,此外还支持两种小数据类型null(空)和undefine(未定义).
javascript:还支持符合数据类型-对象(object),javascript中对象分两种,一种对象表示的已命名的值的无序集合,另一种表示有 编号的值的有序集合。其实有序集合就是数组(Array)。
javascript:还定义了另一种特殊对象----函数,还有一些javascript定义的一些专用对象(等同C#封装的类一样的概念,直接用就行)

<script> 
整型直接量:3或者10000,说白了就是数字 
浮点型直接量:3.14,2345.567等,就是带小数点的 
字符串直接量:"3.14","demo"等,所谓字符串,就是带单引号或双引号括起来的Unicode字符序列。 
把数字转换为字符串:1,var s = 100; s+="What you name";数字就会先 
转换成字符串 
2,var s = 100 +"";加一个空字符串 
3.要让数字更显示的转换为字符串可以使用 String()函数或 
者使用toString函数。 
把字符串转换为数字:var product = "2" * "2";其实当一个字符串用于数字环 
境 中它会自动地转换成一个数字,也可以通过减0也可达到同样的效果,或者使用 
Number()函数 
布尔值: 
在这里我想和大家分享的内容还是转换:今后用的会比较多。1、当一个布尔值用在数字环境中,true就转换为数字1,而false转换成数字0,在字符串环境中,true就转换成字符串true,而false就转换成字符串false 
函数: 
函数是一个可执行的JavaScript代码段。这里说一下:函数作为数据类型,也可以像其他类型一样赋给对象的属性,当赋值成功后,属性常常当做是哪个方法的引用。后面常用。 
函数直接量:var square = function(x){return x*x};//后面常用到,要能理解或记住 
</script>

Javascript:二、对象
1、对象
<script> 
var o = new Object();//大家注意,javascript大小写敏感! 
var now = new Date() 
var regex = new RegExp("^\+?\d{1}\d{3}$")//正则表达式 
对象的直接量: 
var point = {x:12,y:34}; 
var point2 = {"super":{day:sunday,day1:monday}}//对象的属性引用另一个对象。 
对象的转换: 
当一个非空的对象用于布尔环境时:它转换为true,当用在字符串环境中是,javascript会调用对象的toString()方法,并且使用该函数返回的值,当用于数字环境时:javascript 会调用该对象的valueOf()方法,如果返回的是一个基本类型,这个值会被使用,大多数的时候返回的是对象自己,这种情况下javascript回调用toString()方法把对象转换成一个字符串,然后在试图转换成数字。这上面的概念,希望大家也要理解,以后会用到。 
</script>

2、数组
<script> 
var array = new Array(); 
var arr = new Array(1.2,"Javascript",{x:12,y:23})//带参数的 
数组直接量: 
var a = [1.2,"Javascript",{x:12,y:23}]//数组是[]号,对象是{}号,很好记! 
</script>

3、Null(空)
javascript的关键字Null 是一个特殊的值,它表示无值,null 常被看作对象类型的一个特殊值,即代表无对象的值,当一个变量的值
为null,那么就说明它的值不是有效的(Array,Object,数字,字符串,布尔值), 细节:null 在布尔环境中它转换成false;在数字
环境中转换成0。
4、Undefined(未定义)
在使用一个并未声明的变量时,或者使用了已经声明的变量但没有赋值的变量时,又或者是使用一个并不存在的对象属性是,返回的
就是undefined值,在往后的(命名空间,模块用的还是蛮多,大家要理解),细节:underfined在布尔环境中它转换成false,在数字环境
它会转换成NaN。这一点和null有区别。封装它的对象是Error。
小结:以上内容虽然一看就懂,希望和我一样初学的朋友们,千万不要大意!
JavaScript 基础篇 (二)
基础篇
javascript:变量的声明
以下是几种声明变量的方式
var value; 
var value,value1,value2;//同时声明多个变量,但是这些变量的值都是undefined 
var i = 0,j = 0,k=100;//变量声明,初始化一体。 
//如果大家尝试读一个不存在的变量(值)会报错!但是尝试给一个未使用Var声明的变量赋值,javascript 
//会隐式的声明改变量,而且声明了的变量还是全局的。细节:所以大家创建变量都尽量使用Var 
//变量的作用域(这个问题也容易出,大家要搞明白)

javascript:变量的作用域
这些都是细节,和我一样初学的一定要注意避免!
var golbal = "golbal"; //全局变量 
var local ="local"; 
function area() 
{ 
//局部变量的优先级比全局变量的高 
var local = "arealocal" 
//当函数体内声明的变量名和全局变量名相同时,javascript 会隐藏全局变量 
var golbal ="areagolbal"; 
document.write("local is :"+local + "and golbal is :" + golbal +"<br />"); 
} 
area(); 
//输出:local is :arealocaland golbal is :areagolbal

在嵌套的函数里面定义局部变量,效果会怎么样呢?看下面:
var hope = "moremoney"; 
function createmore() 
{ 
var hope = "have more money";//局部 
function createmoreto()//嵌套函数 
{ 
var hope = "have more money to much";//局部 
document.write("Createmoreto hope is :"+hope +"<br />"); 
//输出:Createmoreto hope is :have more money to much 
} 
createmoreto();//调用 
document.write("Createmore hope is :" +hope +"<br />"); 
//输出:Createmore hope is :have more money 
} 
createmore(); //调用

javascript:传值和传址
这里也是比较重要的概念!不要漏了。
传值 



传址 
复制 实际复制的值,存在不同的、 




 复制的只是对数字的引用。如果通过这个 
独立的拷贝。 




 新的引用修改了数值,这个改变对最初的 












引用来说也是可见的。 
传递 传递给函数的是值的独立拷贝 





传递给函数的是对数值的引用,如果函数 
对它的改变在函数外没有影响 





通过传递给它的引用修改了数值,这个改 












 变也是可见的。 


 
比较 比较这两个对立的值,通常逐 





比较的是两个引用,以判断它们引用的是否 
字节的比较,以判断是否相等 



 

是同一个数值。

javascript:基本类型和引用类型
javascript的基本规则是:基本类型通过传值来操作,引用类型通过传址来操作。(什么事值类型,或者什么事引用看我上一篇)
按值传递 
var value = 1; 
var copyvalue = value; //将value赋给另一个变量 
function addTotal(total,arg) 
{ 
total+= arg; //total = total + arg 效果等同 
} 
//调用函数,传两个参数(大家可能会认为这个函数改变了全局变量的值,其实没有,函数用的也是对立拷贝) 
addTotal(value,copyvalue); 
if(value == 1) copyvalue = 2; 
document.write("total \t" + value + "and copyvalue \t\t" + copyvalue+"<br />"); 
//最后输出:total 1and copyvalue 2

按址传递 
var array = new Array("Javascccp"); 
var objarray = array; 
function modifyArray(arr) 
{ 
arr[0] = "JAVASCRIPT"; 
} 
//没调用函数前 
document.write(array[0] +"<br />"); 
//输出Javascccp; 
//调用函数后 
modifyArray(array); 
document.write(array[0]+"<br />"); 
//输出大写JAVASCRIPT 
//通过修改objarray会是一样的效果 
objarray[0] = "Frank"; 
document.write(array[0]+"<br />"); 
//输出Frank;

小结:上面内容希望大家都不要错过,对学习后面的知识还是很有帮助的!
Javascript 相关文章推荐
jquery仿QQ商城带左右按钮控制焦点图片切换滚动效果
Jun 27 Javascript
解决json日期格式问题的3种方法
Feb 02 Javascript
JavaScript通过select动态更换图片的方法
Mar 23 Javascript
JavaScript实现的多个图片广告交替显示效果代码
Sep 04 Javascript
Bootstrap按钮组件详解
Apr 26 Javascript
JS常见创建类的方法小结【工厂方式,构造器方式,原型方式,联合方式等】
Apr 01 Javascript
微信小程序实现简单input正则表达式验证功能示例
Nov 30 Javascript
AjaxFileUpload.js实现异步上传文件功能
Apr 19 Javascript
Vue 3.x+axios跨域方案的踩坑指南
Jul 04 Javascript
JS实现打字游戏
Dec 17 Javascript
vue 子组件修改data或调用操作
Aug 07 Javascript
js实现鼠标切换图片(无定时器)
Jan 27 Javascript
js确定对象类型方法
Mar 30 #Javascript
js 浏览器事件介绍
Mar 30 #Javascript
js中eval详解
Mar 30 #Javascript
关于jquery性能最佳实践的讨论,与求教
Mar 30 #Javascript
从面试题学习Javascript 面向对象(创建对象)
Mar 30 #Javascript
jQuery 自定义函数写法分享
Mar 30 #Javascript
一个JQuery操作Table的代码分享
Mar 30 #Javascript
You might like
一个php作的文本留言本的例子(五)
2006/10/09 PHP
解决php使用异步调用获取数据时出现(错误c00ce56e导致此项操作无法完成)
2013/07/03 PHP
php检查函数必传参数是否存在的实例详解
2017/08/28 PHP
PHP实现打包zip并下载功能
2018/06/12 PHP
laravel excel 上传文件保存到本地服务器功能
2019/11/14 PHP
[原创]静态页面也可以实现预览 列表不同的显示方式
2006/10/14 Javascript
jquery解决图片路径不存在执行替换路径
2013/02/06 Javascript
jQuery的控件及事件(输入控件及回车事件)使用示例
2013/07/25 Javascript
javascript搜索框点击文字消失失焦时文本出现
2014/09/18 Javascript
JavaScript结合Bootstrap仿微信后台多图文界面管理
2016/07/22 Javascript
探讨跨域请求资源的几种方式(总结)
2016/12/02 Javascript
BootStrap表单宽度设置方法
2017/03/10 Javascript
vue2.0嵌套路由实现豆瓣电影分页功能(附demo)
2017/03/13 Javascript
jquery网页加载进度条的实现
2017/06/01 jQuery
vue+webpack实现异步组件加载的方法
2018/02/03 Javascript
vue 弹框产生的滚动穿透问题的解决
2018/09/21 Javascript
详解axios中封装使用、拦截特定请求、判断所有请求加载完毕)
2019/04/09 Javascript
vue项目前端错误收集之sentry教程详解
2019/05/27 Javascript
Vue+Element UI+vue-quill-editor富文本编辑器及插入图片自定义
2019/08/20 Javascript
微信小程序实现时间进度条功能
2020/11/17 Javascript
node.js 使用 net 模块模拟 websocket 握手进行数据传递操作示例
2020/02/11 Javascript
[04:04]DOTA2亚洲邀请赛比赛场馆&酒店全攻略
2017/03/23 DOTA
Python扩展内置类型详解
2018/03/26 Python
python远程调用rpc模块xmlrpclib的方法
2019/01/11 Python
python实现windows壁纸定期更换功能
2019/01/21 Python
python pexpect ssh 远程登录服务器的方法
2019/02/14 Python
python在OpenCV里实现投影变换效果
2019/08/30 Python
window环境pip切换国内源(pip安装异常缓慢的问题)
2019/12/31 Python
Python实现大数据收集至excel的思路详解
2020/01/03 Python
Python 读取xml数据,cv2裁剪图片实例
2020/03/10 Python
遗体告别仪式答谢词
2014/01/23 职场文书
2014年应届大学生毕业自我鉴定
2014/01/31 职场文书
双创工作实施方案
2014/03/26 职场文书
社区五一劳动节活动总结
2015/02/09 职场文书
关于观后感的作文
2015/06/18 职场文书
2016大学生国家助学贷款承诺书
2016/03/25 职场文书