// 作业

//深度拷贝

var
obj = {

name:'rong',

age:'25',

card:['visa','alipay'],

nam :['1','2','3','4','4']

}

 

function
clone (orig,target){

var
target = target||{};

 

var
arrstr= '[object Array]';

 

for(var
prop
in
orig){

if(orig.hasOwnProperty(prop)){

 

if (typeof(orig[prop]) == 'object'){

if((Object.prototype.toString.call(orig[prop])) == arrstr)

{

target[prop] = [];

}else{

target[prop] = {};

}

clone(orig[prop],target[prop]);

 

}else{

target[prop] = orig[prop];

}

}

}

return
target;

}

var
obj1 = {};

clone(obj,obj1);

 

//三步运算符
?:
判断条件

则走前面

则走后边

//简化代码

 

var
obj = {

name:'rong',

age:'25',

card:['visa','alipay'],

nam :['1','2','3','4','4']

}

 

function
clone (orig,target){

var
target = target||{};

 

var
arrstr= '[object Array]';

 

for(var
prop
in
orig){

if(orig.hasOwnProperty(prop)){

 

if (typeof(orig[prop]) == 'object'){

 

target[prop] = ((Object.prototype.toString.call(orig[prop])) == arrstr)?

[]:{};

clone(orig[prop],target[prop]);

 

}else{

target[prop] = orig[prop];

}

}

}

return
target;

}

var
obj1 = {};

clone(obj,obj1);

 

//toString s必须大写

// hasOwnProperty

// Object.prototype.toString.call O大写

 

//数组操作方法

 

// push()---从数组最后一位开始插入数据(参数)
返回值为数组长度

// pop()----剪切数组最后一位数据
(没有参数,返回值为最后一位数据)

 

// unshift() ----从数组第一位插入数据

// shift() ----剪切数组第一位数据

 

// splice() 从第几位开始,截取多少长度,在切口处添加新数据,添加的数据长度不一定等于截取的数据,返回值为截取数据组成的数组

 

// reverse() 数字逆转顺序
返回逆转后的数组

 

// sort()

// 对数组进行排序,返回值为改变后的数组,按照字符串的ascall码排序,空值为默认值,升序排列

// 参数必须为函数

// 1、必须写俩形参

// 2、看返回值,当返回值为负数时,那么前面的数放前面

// 为正数,那么后边的数放在前面

,不动

 

// concat 链接两个数组
并返回一个新数组,原数组不变 arr.concat(arr1) ,将arr1数组内容加到arr后边,返回一个新数组


从第一位开始截取到第3位(含)并返回截取部分数组,原数组不改变,一位参数为从第n位开始

// 截取到末位,无参数为截取整个数组

// jion('-') 参数为字符串,按照字符串中内容为连接符连接数组,返回一个字符串

// split('-') 按照参数将字符串拆分成字符串
与jion逆操作

// 类数组

// 属性要为索引(数字)
属性,必须有length属性,最好有push方法

 

// 作业

// 封装typeof

// typeof的返回值共有六种:

// number, boolean, string, undefined, object, function.

 

// number

// typeof(10);

// typeof(NaN);

// //NaN在JavaScript中代表的是特殊非数字值,它本身是一个数字类型。

// typeof(Infinity);

//

/////////2.boolean

// typeof(true);

// typeof(false);

 

//////// 3.string

// typeof("abc");

 

// ///////4.undefined

// typeof(undefined);

// typeof(a);//不存在的变量

 

// ///////5.object

// 对象,数组,null返回object

// typeof(null);

// typeof(window);

 

// //////6.function

// typeof(Array);

// typeof(Date);

 

//分类 number string boolean function undefind 无需判断
只需判断object

 

function
type(a) {

if(typeof(a) !=="object"){

return
typeof(a);

}else {

return
Object.prototype.toString.call(a);

}

 

}

 

// 数组去重

// 要求在原型链编程

Array.prototype.unique = function (){

var
b = [];

for(var
i = 0; i < this.length; i++){

for(var
j = 0;j < b.length; j++){

if(this[i] === b[j])

{break;}

}

if(j == b.length){b.push(this[i])}

}

return
b;

 

}

//利用对象的特性,属性名不能重复,为每个属性赋值,依次判断是否有值

Array.prototype.unique = function (){

var
obj = {},

arr = [],

len = this.length;

for(var
i = 0;i < len; i++ ){

if(!obj[this[i]]){

obj[this[i]]= "1";

//判断obj中this[i]是不是undefind,如果是
就说明此属性名没有,则赋值1,

arr.push(this[i]);

}

}

return
arr;

}

 

 

//函数形式

// function test (a){

// var b = [];

// for(var i = 0; i < a.length; i++){

// for(var j = 0;j < b.length; j++){

// if(a[i] === b[j])

// {break;}

// }

// if(j == b.length){b.push(a[i])}

// }

// return b;

 

// }

Js笔记-第17课的更多相关文章

  1. 奇舞js笔记——第0课——如何写好原生js代码

    摘要 1.好的代码职责要清晰,javscript不要用来操作样式: 2.API要设计的合理:通用性,适度的抽象(数据抽象,过程抽象),可扩展性: 3.效率问题:用好的.合适的算法(前端程序员要把自己当 ...

  2. Js笔记-第11课

    // 第11课         作用域精解     运行期上下文,当函数执行时,会创建一个成为执行期上下文的内部对象.一个执行期上下文定义了一个函数执行时的环境,函数每次执行时对应的执行期上下文都是独 ...

  3. CoolBlog开发笔记第2课:搭建开发环境

    教程目录 1.1 CoolBlog开发笔记第1课:项目分析 前言 今天是CoolBlog开发笔记的第2课,我们将要讲解的是开发环境的搭建.俗话说"工欲善其事必先利其器",Djang ...

  4. CoolBlog开发笔记第4课:数据库模型设计

    教程目录 1.1 CoolBlog开发笔记第1课:项目分析 1.2 CoolBlog开发笔记第2课:搭建开发环境 1.3 CoolBlog开发笔记第3课:创建Django应用 前言 我新书<Py ...

  5. CoolBlog开发笔记第5课:请求与响应

    教程目录 1.1 CoolBlog开发笔记第1课:项目分析 1.2 CoolBlog开发笔记第2课:搭建开发环境 1.3 CoolBlog开发笔记第3课:创建Django应用 1.4 CoolBlog ...

  6. SQL 必知必会-- 第17课:创建和操作表

    我这里用的是oracle 10g,PL/SQL来做的. 第17课  创建和操纵表  14517.1  创建表  14517.2  更新表  15017.3  删除表  15317.4  重命名表  1 ...

  7. Android菜鸟的成长笔记(17)—— 再看Android中的Unbounded Service

    原文:Android菜鸟的成长笔记(17)-- 再看Android中的Unbounded Service 前面已经写过关于startService(Unbounded Service)的一篇文章:&l ...

  8. CoolBlog开发笔记第3课:创建Django应用

    教程目录 1.1 CoolBlog开发笔记第1课:项目分析 1.2 CoolBlog开发笔记第2课:搭建开发环境 前言 经过上一节我们已经创建了CoolBlog工程,但是关于CoolBlog的功能代码 ...

  9. 第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; Select 列 into 新表;字符串函数;日期函数

    第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all;  ...

随机推荐

  1. qsc52(三角形线性插值)

    题目链接:http://qscoj.cn/problem/52/ 题意:中文题诶- 思路:水题,只要知道三角形插值和判断点在三角形内就OK了 关于三角形插值:http://www.cnblogs.co ...

  2. [NOIP2012] 摆花

    1270. [NOIP2012] 摆花 http://cogs.pro/cogs/problem/problem.php?pid=1270 ★   输入文件:flower.in   输出文件:flow ...

  3. 图论2 最近公共祖先LCA

    模板 吸取洛谷P3379的教训,我决定换板子(其实本质都是倍增是一样的),把vector换成了边表 输入格式: 第一行包含三个正整数N.M.S,分别表示树的结点个数.询问的个数和树根结点的序号. 接下 ...

  4. JavaScript进阶 - 第3章 一起组团(数组)

    第3章 一起组团(数组) 3-1 一起组团(什么是数组) 我们知道变量用来存储数据,一个变量只能存储一个内容.假设你想存储10个人的姓名或者存储20个人的数学成绩,就需要10个或20个变量来存储,如果 ...

  5. STP-10-RPVST+

    RPVST+(快速每VLAN生成树+)是一种以每个VLAN为基础,分别运行RSTP的形式,类似于PVST+.它拥有之前所描述的PVST+的优势,这为RSTP带来了亚秒级的收敛速度.因此,RPVST+和 ...

  6. Django之ORM跨表操作

    Django之ORM表查询及添加记录 一.创建表 - 书籍模型: 书籍有书名和出版日期,一本书可能会有多个作者,一个作者也可以写多本书,所以作者和书籍的关系就是多对多的关联关系(many-to-man ...

  7. [LOJ 2070] 「SDOI2016」平凡的骰子

    [LOJ 2070] 「SDOI2016」平凡的骰子 [题目链接] 链接 [题解] 原题求的是球面面积 可以理解为首先求多面体重心,然后算球面多边形的面积 求重心需要将多面体进行四面体剖分,从而计算出 ...

  8. input密码自动填充

    自动填充样式修改 input: -webkit - autofill, input: -webkit - autofill: hover, input: -webkit - autofill: foc ...

  9. Prime Count 求大区间素数个数

    http://acm.gdufe.edu.cn/Problem/read/id/1333 https://www.zhihu.com/question/29580448/answer/44874605

  10. mysql查看各个表的大小

    information_schema 数据库,在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHEMA : 数据库名 TABLE_NAME:表名 ENGINE:所使用的存储引 ...