js arguments,克隆,三目运算符,数组,类数组 07-25

克隆
1.arguments.callee


image.png

这个返回的其实就是ff函数的引用:


image.png

这个引用和ff是一样的,就是代表了一个一模一样的函数

下面是一个应用:


image.png

这是一个在一个立即执行函数里面计算阶乘的方法

下面是一个深赋值的例子


image.png
var obj={
            name:"abc",
            age:123,
            card:['visa','master'],
            wife:{
                name:"bcd",
                son:{
                    name:"aaa"
                }
            }
        }
        var obj1={
    
        }
        function deepClone(origin,target){
            var target=target || {},
            toStr=Object.prototype.toString,
            arrStr="[Object Array]";
            for(var prop in origin)
            {
                if(origin.hasOwnProperty(prop))
                {
                    if(origin[prop]!=='null'&&typeof(origin[prop])=='object')//就说明是引用类型
                    {
                        if(toStr.call(origin[prop])==arrStr){
                            target[prop]=[];
                        }
                        else{
                            target[prop]={};
                        }
                        deepClone(origin[prop],target[prop]);
                    }
                    else{
                        target[prop]=origin[prop];
                    }
                }
            }
            return target;
        }

三目运算符

对于有些选择分支结构,可以使用简单的条件运算符来代替. 如:

  if(a<b)
      min=a;
  else
      min=b;

  可以用下面的条件运算符来处理

  min=(a<b)?a:b;


  其中"(a<b)?a:b"是一个"条件表达式",它是这样执行的: 如果a<b为真,则表达式取a值,否则取b值.

  条件运算符由两个符号组成"?"和":", 要求有3个操作对象,所以也叫它三目运算符,它是C语言中唯一的三目运算符.

    它的一般形式为:

        表达式1?表达式2:表达式3;

以下是关于条件运算符的几点说明:

(1) 表达式1是关系表达式或逻辑表达式,用于描述条件,表达式2和表达式3可以是常量,变量或表达式.如:

      (x==y)?'Y':'N'
      (d=b*b-4*a*c)>=0?sqrt(d):sqrt(-d)
      ch=(ch>='A'&&ch<='Z')?(ch+32):ch

        以上均为合法的条件表达式.

     (2) 执行顺序:先求解表达式1,若值为非0,表示条件为真,则求表达式2,此时表达式2的值就作为整个条件表达式的值;

      若表达式1的值为0,表示条件为假,则求解表达式3,表达式3的值就是整个条件表达式的值.例如:

        (a>=0)?a:-a   执行结果是a的绝对值.

      (3) 在程序中,通过把条件表达式的值直接赋予某个变量.例如:

        min=(a<b)?a:b  执行结果就是将条件表达式的值赋予变量min,即将a和b二者中较小的数赋给min.

     (4) 条件表达式的优先级别仅高于赋值运算符,而低于前面遇到过的所有运算符.

        因此,min=(a<b)?a:b括号可以不要,可直接写成,min=a<b?a:b如果有x<y?x+1:y-1等效于x<y(x+1):(y-1)而不等效于(x<y?x+1:y)-1

    (5) 条件运算符的结合方向为"自右至左".

     (6) 条件表达式允许嵌套,即允许条件表达式中的表达式2和表达式3又是一个条件表达式.例如:

        x>0?1:x<0?-1:0

       上述条件表达式中,表达式3部分又是一个条件表达式.根据条件表达式的结合性,上述条件表达式等价于:

          x>0?1:(x<0?-1:0)

       其作用是判断x的符号情况.当x为正数时,该条件表达式的值为1;当x为负数时,该条件表达式的值为-1;当x为0时,该条件表达式的值为0.

     (7) 条件表达式仅当if语句中内嵌的语句为赋值语句(且两个分支都给同一变量赋值)时才能代替if语句.如:

         if(a%2==0)
            printf("even/n");
        else
            printf("odd/n");

      不能写成:

         (a%2==0)?printf("even/n"):printf("odd/n");

      但可以用下面语句代替:

         printf("%s/n",(a%2==0?"even":"odd");

      该语句的作用是:若 a 为偶数,输出 even;若 a 为奇数,输出odd.

       (8) 表达式1,表达式2,表达式3的类型可以不同.此时条件表达式的值的类型为它们中较高的类型.例如:

        main() {

          char c1, ch;

          ch = getchar();

          c1 = ch <= 'Z' && ch >= 'A' ? ' @ ' : ch ;

          putchar(c1);

        }

该程序的作用是从键盘输入任意一个字符,判别它们是否大写字母,如果是,输出一个@;否则按原样输出 dot

上例中,程序第6行是关键语句,该语句实现输入字符的判断,选择与更换工作.

其执行过程为:先由此语句中的赋值号右侧的条件运算符对输入的字符进行判断和选择,若ch>='A'&&ch<='Z'成立,说明ch是大写英文字母,此时选@;否则仍选原字符ch,然后把选择的结果赋值给原变量ch 。

数组,类数组

类数组对象:(看例子)       
var a = {};       

var i =10;

while(i<10){

 a[i] = i*i;

i++;

}

数组对象:

var b = [];

var i =0;

while(i<10){

b[i] = i*i;

i++;

}

其实你从源代码上面去看也没有什么大的区别:

但是js中是支持 1: 类名【属性名称】 = 值 相当于 2:类名.属性名称 = 值

要是你想在类中使用动态的属性 就必须用第一个

下面看下下区别吧:

类数组对象:

console.log(typeof a);//object 注意:数组也是对象哦

console.log(a); //  Object {0: 0, 1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64, 9: 81} 很明显对象啊

console.log(a.length); //undefined  区别就在这了  类数组对象没有长度的属性和数组的方法

console.log(Object.prototype.toString.call(a));//[object Object] 

数组对象:

console.log(typeof b);//object

console.log(b);//  [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]  很明显数组啊 

console.log(b.length); //8

console.log(Object.prototype.toString.call(b));//[object Array]

在上一个判断是对象还是数组的方法

var isArray = Function.isArray || function(o){

 return typeof o === "object" && Object.prototype.toString.call(o) == "[object Array]";

}

​
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,114评论 0 13
  • 一、Java 简介 Java是由Sun Microsystems公司于1995年5月推出的Java面向对象程序设计...
    子非鱼_t_阅读 4,146评论 1 44
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,318评论 0 2
  • 公司有法人一证通的前提下: 1.带上公司营业执照(正本)复印件 2.公司公章 3.经办人身份证原件及复印件 4.填...
    一个快乐的沙子阅读 521评论 0 0
  • 他和你同样孤独,同样走在莽然而生的大地之上。你以为你们不同,看着他乌溜转动的眼睛,摸着挺直的鼻子,舔着干涸的嘴唇,...
    Pomeloman阅读 376评论 0 6