匿名函数:  

没有名字的函数,函数整体加小括号不报错,

函数调用 :

  a:直接调用

(function (){函数体}) ( ) ;

  b:事件绑定 document.onlick = function ( ) { 函数体;}     // 暂时了解即可

  c:定时器调用

递归

递归是一种思想:类似于我们的计数器,开闭原则。

递归的实质就是函数自己调用自己/但是要注意  必须有跳出条件

alert (aim (100));
function sum(n){
if (n<1){
return 0 ;
}
sum = n + sum(n-1) ; return sum ;
}

回调函数

  函数作为参数进行传递

  函数形参后加小括号

    a:函数作为参数进行传递和使用

    b: (function(){console.log("从前有朵花,然后")})();   //会自动运行

      函数名 ();  //即可自动运行,一般用于定义一个规则/规则的传递只能通过函数实现,通过变量无法实现

    

function fn(num1,num2,demo) {
return demo(num1,num2);
}
function text1 (a,b) { return a+b } ; // 会在控制台输出 5+8的结果 : 13
console.log ( fn(5,8,text1) );

对象

  1. 封装信息
  2. 对象具有特征和行为
  3. 3.  生活中的对象:具有唯一性的事和物

a)  生活中一类事物和对象的区别

                 i.      一类事物:保时捷汽车

ii.      对象:具有唯一性,我的那一辆保时捷汽车

b)  一个车,一个手机

  1. 游戏中的对象:

a)  单个角色就是对象

b)  装备就是事物

i.      我用的装备就是对象

c)  金币是事物,我的金币是对象,消费的金币也是对象

d)  有特指的事物是对象

  1. 程序中 对象

a)  var hero = new Object();

i.      hero:就是一个对象

ii.      Object:是一个事物,可以new很多的对象

  1. 面向对象:c/c++,java

a)  可以创建自定义对象,很好的支持继承和多态

b)  特征:封装、继承、多态

基于对象:javascript

  a)  无法创建自定义的类型,

  b)  不能很好的支持继承和多态,

  c)  JS基于对象,只能new出Object对象

属性和方法:状态(名词)和行为(动词)

  a)  属性就是人物信息,行为就是施放技能

  b)  对象中的函数叫方法

  对象名 . 状态 = 匿名函数(){函数体;}:

  c)  对象中的变量叫属性

  对象名 . 属性 = 属性值;

  d)  调用对象的方法和属性

                 i.      调用自己的属性用this . 属性名;

               ii.      调用属性

        对象名.属性名;

             iii.      调用方法

        对象名.方法名();

  1. 对象缺点,

    a)  创建单个对象的时候可以,创建多个对象变得非常繁琐,

    b)  创建多个对象,for循环不能修改名字的值,用函数可以创建多个函数,缺点代码冗余 

    

this

a)  this值出现在函数中

b)  谁调用函数,this就指向谁

c)  new people();people中的this代指的是被创建的对象实例

new

a)  开辟内存空间,存储新创建的对象

b)  把this设置为当前对象

c)  执行内部代码设置对象的属性和方法

d)  创建并返回新的对象

构造函数/自定义对象

  1. new后面调用函数,我们称为构造函数
  2. 构造函数内部不需写对象名字,可用this代替

  

var  str = new Student("尼古拉斯赵四") ;

str.sayHi();

function Studend(name){
this.name = name ;
this.sayHi = function(){console.log ( this.name +"说,我才是真正的亚洲舞王");
}
}

属性绑定

  对象名 . 属性 = 属性值

  对象名[变量名] = 对象值;

进制转换

  1. 将其他制转换为十进制

a)  var num = parseInt(其他进制数,数值是几进制的);

  2.  将十进制转换为其他进制

a)  var num = num.toString(几进制);

十进制的值 = 位值*进制(位数-1+位值*进制(位数-1+位值*进制(位数-1)............

  

javascript . 04 匿名函数、递归、回调函数、对象、基于对象的javascript、状态和行为、New、This、构造函数/自定义对象、属性绑定、进制转换的更多相关文章

  1. 【知识点】inline函数、回调函数、普通函数

    目录 一.inline内联函数 1.1 使用 1.2 编译器对 inline 函数处理步骤 1.3 优缺点 1.3.1 优点 1.3.2 慎用内联 1.3.3 不宜使用内联 1.4 虚函数(virtu ...

  2. C++中类成员函数作为回调函数

    注:与tr1::function对象结合使用,能获得更好的效果,详情见http://blog.csdn.net/this_capslock/article/details/38564719 回调函数是 ...

  3. Go基础系列:函数(2)——回调函数和闭包

    回调函数和闭包 当函数具备以下两种特性的时候,就可以称之为高阶函数(high order functions): 函数可以作为另一个函数的参数(典型用法是回调函数) 函数可以返回另一个函数,即让另一个 ...

  4. C++中 线程函数为静态函数 及 类成员函数作为回调函数

    线程函数为静态函数: 线程控制函数和是不是静态函数没关系,静态函数是在构造中分配的地址空间,只有在析构时才释放也就是全局的东西,不管线程是否运行,静态函数的地址是不变的,并不在线程堆栈中static只 ...

  5. php自定义函数之回调函数

    回调函数,可以配合匿名函数和变量函数实现更加优美.复杂的一种函数结构.大理石平台价格 回调函数,就是在处理一个功能的时候,我让让这个功能自定义能力再强一些,我准许调用这个函数的时候,还可以传入一个函数 ...

  6. php变量函数,回调函数

    一,变量可以直接传递函数 <?php function demo($num , $n )//$n是个函数 { for($i=0;$i<$num;++$i) { if($n($i)) { e ...

  7. Python内置进制转换函数(实现16进制和ASCII转换)

    在进行wireshark抓包时你会发现底端窗口报文内容左边是十六进制数字,右边是每两个十六进制转换的ASCII字符,这里使用Python代码实现一个十六进制和ASCII的转换方法. hex() 转换一 ...

  8. chr()//ord() //进制转换函数//eval()//文件函数//split()

    1.chr() 函数 chr() 用一个范围在 range(256)内的(就是0-255)整数作参数,返回一个对应的字符. 用法:chr(i) i可以是10进制也可以是16进制的形式的数字. 2.or ...

  9. SQL Server 进制转换函数

    一.背景 前段时间群里的朋友问了一个问题:“在查询时增加一个递增序列,如:0x00000001,即每一个都是36进位(0—9,A--Z),0x0000000Z后面将是0x00000010,生成一个像下 ...

随机推荐

  1. Yii框架中的form表单

    <?php//引入命名空间use yii\helpers\Html;?><?php //表单:Html::beginForm(提交地址,提交方法,属性数组);?><?=H ...

  2. Eclipse运行时无法加载主类的解决方法

    测试代码: package javastudy; class Person { public static void main(String[] args) { PersonCeshi pp=new ...

  3. sqlite数据库学习

    1.0版代码: package com.swust.sqlitedatabase.test; import com.swust.sqlitedatabase.myOpenHelper; import ...

  4. Apache Pig处理数据示例

    Apache Pig是一个高级过程语言,可以调用MapReduce查询大规模的半结构化数据集. 样例执行的环境为cloudera的单节点虚拟机 读取结构数据中的指定列 在hdfs上放置一个文件 [cl ...

  5. PHP结合memcacheq消息队列解决并发问题

    在处理业务逻辑时有可能遇到高并发问题,例如商城秒杀.微博评论等.如果不做任何措施可能在高瞬间造成服务器瘫痪,如何解决这个问题呢?队列是个不错的选择.队列(Queue)又称先进先出(First In F ...

  6. 自定义checkbox/radio

    一. label标签 1. 概念: HTML <label>元素表示用户界面中项目的标题.它通常关联一个控件,或者是将控件放置在label元素内,或者是用作其属性.这样的控制称作label ...

  7. Android源码编译常见错误(持续更新)

    本文为个人工作中处理遇到的编译问题做个小结,后续遇到新的问题,持续更新. No such file or directory: 1. 检查路径是否有问题,文件是否存在,若文件存在且路径没问题 2. 检 ...

  8. 史上最全的AJAX

    概述 对于web应用程序:用户浏览器发送请求.服务器接收并处理请求,然后返回结果,往往返回就是字符串(HTML),浏览器将字符串(HTML),渲染并显示浏览器上· Ajax和Form表单提交数据的的好 ...

  9. 提交Sublime Text 插件到Package Control

    最近写了一个lua智能提示的插件LuaSmartTips.这个插件一直都是自己一个人在用,昨天突然想把插件提交到Package Control,如果其他的人有这样的需求就可以直接安装. Package ...

  10. UI设计学习路线图

    文章转载自「开发者圆桌」一个关于开发者入门.进阶.踩坑的微信公众号 这里整理的UI设计学习路线图包含初中高三个部分,你可以通过百度云盘下载观看对应的视频 链接: http://pan.baidu.co ...