03.深入javascript
函数返回值
函数返回值和函数传参正好相反,函数传参是我们可以把一些东西传到函数里面去,函数返回值是函数可以把一些东西传到外面来。
<script>
function show()
{
return 12;
}
alert(show());// 弹出12 在哪调用返回到哪
</script> <script>
function show(a, b)
{
return a+b;
} alert(show(3, 5));//弹出8
</script>
一个函数应该只返回一种类型的值
<script>
function show()
{
}
alert(show());
</script>
//弹出 undifined 函数也可以没有返回值
函数传参
可变参(不定参):arguments 是一个数组,参数的个数可变,参数数组
例子 求和
<script>
function sum()
{
var result=0;
for(var i=0;i<arguments.length;i++)
{
result=result+arguments[i];
}
return result;
}
alert(sum(12, 6, 8, 6, 8,8));
css(oDiv, 'width') 获取样式
arguments[0] oDiv
arguments[1] width
arguments[2] 200px
css(oDiv, 'width', '200px') 设置样式
<div id="div1" style="width:200px; height:200px; background:red;"> </div>
<script>
function css()
{
if(arguments.length==2) //获取
{
return arguments[0].style[arguments[1]];
}
else
{
arguments[0].style[arguments[1]]=arguments[2]; //设置
}
} window.onload=function ()
{
var oDiv=document.getElementById('div1'); //alert(css(oDiv, 'width')); css(oDiv, 'background', 'green');
};
</script>
用传参的方式 obj, name, value
<script>
function css(obj, name, value)
{
if(arguments.length==2) //获取
{
return obj.style[name];
}
else
{
obj.style[name]=value;
}
} window.onload=function ()
{
var oDiv=document.getElementById('div1'); alert(css(oDiv, 'width')); //css(oDiv, 'background', 'green');//设置
};
</script>
取非行间样式(不能用来设置):
obj.style用来获取行间样式
obj.currentStyle[attr] 用来获取非行间样式 不过只能兼容ie 火狐谷歌不兼容
getComputedStyle(obj, false)[attr] 兼容火狐谷歌 不兼容ie
复合样式:background、border
单一样式:width、height、position
#div1 {width:200px; height:200px; background:red;}
<script>
function getStyle(obj, name)
{
if(obj.currentStyle)
{
return obj.currentStyle[name];
}
else
{
return getComputedStyle(obj, false)[name];
}
} window.onload=function ()
{
var oDiv=document.getElementById('div1'); alert(getStyle(oDiv, 'backgroundColor'));//background、border属于复合样式需要写成backgroundColor, borderWidth
};
</script>
<div id="div1"></div>
数组的使用
数组定义的两种方法
var arr=[12, 5, 8, 9];
var arr=new Array(12, 5, 8, 9); 没有任何差别,[]的性能略高,因为代码短
数组的属性 length
既可以获取,又可以设置
例子:快速清空数组
<script>
var arr=[1,2,3];
//alert(arr.length); //弹出数组的长度
alert(arr.length=0);//设置数组的长度为0,即清空数组
</script>
数组使用原则:数组中应该只存一种类型的变量
数组添加、删除元素
添加
push(元素),从尾部添加
unshift(元素),从头部添加
删除
pop(),从尾部弹出
shift(),从头部弹出
插入、删除
splice (开始,长度) 删除
splice(开始, 长度,元素…) 先删除,后插入
splice (开始,长度) 删除
<script>
var arr=[1,2,3,4,5,6];
arr.splice(2, 3); //删除:splice(起点, 长度)从第二个位置开始即从数字3开始,删除三个
alert(arr); //弹出的是 1,2,6
</script>
splice(开始, 长度,元素…) 先删除,后插入
<script>
var arr=[1,2,3,4,5,6];
arr.splice(2,0,7,8,9); //先删除在加入:splice(起点, 长度,元素...)从第二个位置开始即从数字3开始,删除0个插入7,8,9
alert(arr); //弹出的是 1,2,7,8,9,3,4,5,6
</script>
转换类
concat(数组2) 连接两个数组
<script>
var a=[1,2,3];
var b=[4,5,6];
//alert(a.concat(b)); //弹出1,2,3,4,5,6 a在左边弹出来的a也在左边
alert(b.concat(a)); //弹出4,5,6,1,2,3 b在左边弹出来的b也在左边
</script>
join(分隔符)
<script>
var arr=[1,2,3,4];
//alert(arr);//弹出的是1,2,3,4
alert(arr.join('-'));//弹出的是1-2-3-4
</script>
排序sort
排序一个字符串数组
排序一个数字数组
排序一个字符串数组
<script>
var arr=['about', 'class', 'die', 'best', 'embed'];
arr.sort();
alert(arr); //弹出的是about,best,class,die,embed
</script>
比较函数 排序一个数字数组
<script>
var arr=[12, 8, 99, 19, 112]; arr.sort(function (n1, n2){
return n1-n2; //按照从小到大排列 弹出112,99,19,12,8
//return n2-n1; //按照从大到小排列 弹出8,12,19,99,112
});
alert(arr);
</script>
03.深入javascript的更多相关文章
- 【干货分享】前端面试知识点锦集03(JavaScript篇)——附答案
三.JavaScript部分 1.谈谈你对Ajax的理解?(概念.特点.作用) AJAX全称为“Asynchronous JavaScript And XML”(异步JavaScript和XML) 是 ...
- 【经验之谈】前端面试知识点总结03(JavaScript相关)——附答案
目录 三.JavaScript部分 1.谈谈你对Ajax的理解?(概念.特点.作用) 2.说说你对延迟对象deferred的理解? 3.什么是跨域,如何实现跨域访问? 4.为什么要使用模板引擎? 5. ...
- 【追寻javascript高手之路03】javascript对象大乱斗
前言 昨天我们学习了下javascript中函数的参数与作用域的东东,现在回过头来看,其实都是与函数相关的,所以javascript中的函数仍然是王道,我们今天大概会发二篇或者三篇博客一起来巩固我们的 ...
- 读书笔记(03) - 性能 - JavaScript高级程序设计
作用域链查找 作用域链的查找是逐层向上查找.查找的层次越多,速度越慢.随着硬件性能的提升和浏览器引擎的优化,这个慢我们基本可以忽略. 除了层级查找损耗的问题,变量的修改应只在局部环境进行,尽量避免在局 ...
- [连载]JavaScript讲义(03)--- JavaScript面向对象编程
- 【学习笔记03】Javascript数组学习
数组定义的方法一: var Myarr=new Array(); //先声明一维 for(var i=0;i<2;i++){ //一维长度2 Myarr[i]=new Array(); //再声 ...
- 【前端学习笔记03】JavaScript对象相关方法及封装
//Object.create()创建对象 var obj = Object.create({aa:1,bb:2,cc:'c'}); obj.dd = 4; console.log(obj.cc); ...
- JavaScript中的百变大咖~this
原文链接:http://www.jeffjade.com/2015/08/03/2015-08-03-javascript-this/ JavaScript作为一种脚本语言身份的存在,因此被很多人认为 ...
- javascript 中this详解
this是每一个想要深入学习Javascript的人必过的一关,我为this看过很多书查过很多资料,虽然对this有了一定的了解并且也经常使用this,但是如果有人问我 this是什么呀? 我依旧不 ...
随机推荐
- IE 8 下的 box-sizing 和 min-* 属性
在非 IE 浏览器中,默认情况下 width 属性指的是内容区域(content)的宽度. IE 6+ 中,如果浏览器以标准模型渲染,和非 IE 浏览器的表现是一致的:如果浏览器以怪癖模式渲染,则 w ...
- php-css外边距
css 基本语法 selector{declaration1;declaration2;....delecrationN;} (选择器和一条或多条声明) 选择器为需要改变样式的html元素,每条声 ...
- 页面localStorage用作数据缓存的简易封装
最近做了一些前端控件的封装,需要用到数据本地存储,开始采用cookie,发现很容易就超过了cookie的容量限制,于是改用localStorage,但localStorage过于简单,没有任何管理和限 ...
- iOS如何跳到系统设置里的各种设置界面
最近项目需要授权时候跳转到相关的设置页面,自己总结了一下,想写到简书上来,和大家分享一下. 在本人测试后,iOS8和9都没有问题,直接跳转到各个页面,这可能苹果对这方面开放了吧.第一步修改plist文 ...
- jq 实现无限级地区联动 样式为bootstrap
HTML 部分 <div class="row" style="margin:100px auto;"> <form method=" ...
- MVC与MVVM区别?
在MVC里,View是可以直接访问Model的!从而,View里会包含Model信息,不可避免的还要包括一些业务逻辑. MVC模型关注的是Model的不变,所以,在MVC模型里,Model不依赖于Vi ...
- [jquery]折叠指定条件的表格
最近在做财务报表时候,一些表格要做特定折叠效果 这里通过2个自定义属性来对表格之间的属性作关联 date-head和date-num,输出表格时候,可以按照这2个自定义属性给某些带父子层级关系的内容指 ...
- MapReduce类型与格式(输入与输出)
一.输入格式 (1)输入分片记录 ①JobClient通过指定的输入文件的格式来生成数据分片InputSplit: ②一个分片不是数据本身,而是可分片数据的引用: ③InputFormat接口负责生成 ...
- python信号signal简单示例
进程间通信之类的,用得着, 可以自定义接到信息之后的动作. file1.py #!/usr/bin/env python # -*- coding: utf-8 -*- import os impor ...
- 如何在 SSAS服务器之间做同步
简介: 从SQL Server 2005开始,分析服务就支持了同步的功能.本文将介绍如何在SQL Server 2012下同步Adventureworks的分析服务数据库.通过同步的功能,我们就来可以 ...