【废弃】【WIP】JavaScript 函数
创建: 2017/10/09
更新: 2017/11/03 加上【wip】
废弃: 2019/02/19 重构此篇。原文归入废弃
增加【废弃中】标签与总体任务
结束: 2019/03/12 完成废弃, 删除【废弃中】标签, 添加【废弃】标签
结束: 2019/03/03 完成废弃, 删除【废弃中】标签, 添加【废弃】标签
| 函数的定义 | |||||||||||||||||||||||||||||||
| 所有声明不分顺序,自动排序 | |||||||||||||||||||||||||||||||
| 普通声明 | function test(a) { return a; } 只有这种在定义后在程序任何位置都可以呼出 |
||||||||||||||||||||||||||||||
| 函数字符来定义 |
var sample = function(a) { 不会被预处理 |
||||||||||||||||||||||||||||||
| Object来定义 |
var name = new function("x", "y", ... , 最后一个是处理,前面都是参数 不会被预处理 |
||||||||||||||||||||||||||||||
| 箭头函数式来定义 |
var sample = x => x*x; 不会被预处理 |
||||||||||||||||||||||||||||||
| 嵌套函数 | 函数内部的函数
|
||||||||||||||||||||||||||||||
| 函数的呼出 | |||||||||||||||||||||||||||||||
| 函数的呼出方法 | function sample() {}
|
||||||||||||||||||||||||||||||
|
即时函数 (无名函数) |
定义与呼出同时进行
|
||||||||||||||||||||||||||||||
| 函数的参数 | |||||||||||||||||||||||||||||||
| 参数的省略 | 省略掉的为undefined undefined是没有赋值 null是赋予的是空值 |
||||||||||||||||||||||||||||||
| 不固定长度的参数 | 所有函数内部可用arguments
|
||||||||||||||||||||||||||||||
| 传值和传参 | object参数传送的是参照(指针) | ||||||||||||||||||||||||||||||
| 递归函数 | |||||||||||||||||||||||||||||||
| 三种写法 |
|
||||||||||||||||||||||||||||||
| 程序的编译与运行 | |||||||||||||||||||||||||||||||
| 生成全局对象 | |||||||||||||||||||||||||||||||
| 解析程序 | |||||||||||||||||||||||||||||||
| 运行程序 | |||||||||||||||||||||||||||||||
| 单线程 | |||||||||||||||||||||||||||||||
| call对象及本地变量 | |||||||||||||||||||||||||||||||
| this的值 |
被呼出函数所属对象 函数内部函数的this是全局变量 |
||||||||||||||||||||||||||||||
| 命名空间 |
var a = "a"; |
||||||||||||||||||||||||||||||
| 垃圾回收 |
释放从全局对象无法到达的量 不用在意 |
||||||||||||||||||||||||||||||
| 闭包 | |||||||||||||||||||||||||||||||
| JavaScript的所有函数都是闭包 闭包内部可以有函数(闭包) |
|||||||||||||||||||||||||||||||
| 应用 | |||||||||||||||||||||||||||||||
| 命名空间 | |||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||
| 用对象管理程序本地代码 |
var myApp = myApp || {};
所有东西追加成属性 |
||||||||||||||||||||||||||||||
| 用函数作为命名空间 |
(function () {
module模式 // 作为即时函数,把module相关传递给指定参数 |
||||||||||||||||||||||||||||||
| 作为对象(Object)的函数 | |||||||||||||||||||||||||||||||
| 函数也是对象 |
● 可以代入变量,对象属性, 数组元素 ● 可以作为函数的参数, 返回值 ● 可以有属性和方法 ● 可以作为不带名字的字符, 即无名函数 function () {} ● 可以动态生成 |
||||||||||||||||||||||||||||||
| 函数的属性(property) |
|
||||||||||||||||||||||||||||||
| 添加自定义属性 |
function test() {...}
|
||||||||||||||||||||||||||||||
| 高阶函数 | |||||||||||||||||||||||||||||||
| 定义 | 以函数为参数或返回值的函数 | ||||||||||||||||||||||||||||||
| 回调函数 | |||||||||||||||||||||||||||||||
| ES6关于函数的扩张 | |||||||||||||||||||||||||||||||
【废弃】【WIP】JavaScript 函数的更多相关文章
- 【JS小技巧】JavaScript 函数用作对象的隐藏问题
用户反馈 @消失的键盘 在论坛反馈了一个问题,在 AppBoxMvc 中的 Title 模型中,如果将 Name 属性改名为小写的 name 属性,就会报错: 因为这是一个 ASP.NET MVC 的 ...
- 【JS小技巧】JavaScript 函数用作对象的隐藏问题(F.ui.name)
用户反馈 @消失的键盘 在论坛反馈了一个问题,在 AppBoxMvc 中的 Title 模型中,如果将 Name 属性改名为小写的 name 属性,就会报错: 因为这是一个 ASP.NET MVC 的 ...
- 专题8:javascript函数详解
函数是一段可以反复调用的代码块.函数还能接受输入的参数,不同的参数会返回不同的值. 函数的声明 JavaScript 有三种声明函数的方法. (1)function 命令 function命令声明的代 ...
- ABP(现代ASP.NET样板开发框架)系列之21、ABP展现层——Javascript函数库
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之21.ABP展现层——Javascript函数库 ABP是“ASP.NET Boilerplate Project ...
- JavaScript权威设计--JavaScript函数(简要学习笔记十一)
1.函数调用的四种方式 第三种:构造函数调用 如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内.这和函数调用和方法调用是一致的.但如果构造函数没有形参,JavaScri ...
- JavaScript 函数
JavaScript 函数 介绍:函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块.嗯,就像Java中封装的方法一样. 将脚本编写为函数,就可以避免页面载入时执行该脚本. 函数包含着一些代码 ...
- javascript 函数初探 (一)--- 神马是函数
神马是函数? 所谓函数,本质上是一种代码的分组形式.我们可以通过这种形式赋予某组代码一个名字,以便与之后的调用.下面,我们来示范以下函数的声明: function sum(a, b){ var c = ...
- JavaScript函数的概念
函数是这样的一段代码,它只定义一次,但可能被执行或调用任意多次. JavaScript函数是参数化的:函数的定义会包含形参,这些参数在函数的整体中像局部变量一样工作.函数调用时会为形参提供实参的值.除 ...
- Javascript函数重载,存在呢—还是存在呢?
1.What's is 函数重载? );//Here is int 10 print("ten");//Here is string ten } 可以发现在C++中会根据参数的类型 ...
- JavaScript 函数声明,函数表达式,匿名函数,立即执行函数之区别
函数声明:function fnName () {-};使用function关键字声明一个函数,再指定一个函数名,叫函数声明. 函数表达式 var fnName = function () {-};使 ...
随机推荐
- Python字符的转义
参考原文 廖雪峰Python教程 字符的转义 字符串是以单引号' 或双引号" 括起来的任意文本,比如'abc',"xyz".''或""本身只是一种表示 ...
- How To:分析ORACLE监听日志中的IP信息
有时候需要分析出ORACLE日志监听中的IP信息,分享一个组合命令,Linux的shell下运行正常. grep "HOST=.*establish.*\* 0" listener ...
- cookie的原理
一般来说,Cookie通过HTTP Headers从服务器端返回到浏览器上.首先,服务器端在响应中利用Set-Cookie header来创建一个Cookie ,然后,浏览器在它的请求中通过Cooki ...
- css实现圆角效果
源码: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> & ...
- 整理推荐比较好用的具有书签搜索功能的chrome插件
平时在整理学习chrome插件的过程中,经常会去试用各种大家推荐的插件.在去年我们的一篇文章:推荐六款好用的书签收藏夹剪藏型管理插件.这里面介绍的是收藏书签的插件.而随着我们使用chrome越来越频繁 ...
- 如何使用loadrunner进行web网站性能测试
loadrunner压力测试原理 本质就是在loadrunner上模拟多个用户同时按固定行为访问web站点.其中固定行为在loadrunner中是通过录制脚本定义的,多个用户同时访问的策略是在load ...
- 【Codeforces 675D】Tree Construction
[链接] 我是链接,点我呀:) [题意] 依次序将数字插入到排序二叉树当中 问你每个数字它的父亲节点上的数字是啥 [题解] 按次序处理每一个数字 对于数字x 找到最小的大于x的数字所在的位置i 显然, ...
- CodeForcesGym 100753B Bounty Hunter II
Bounty Hunter II Time Limit: 5000ms Memory Limit: 262144KB This problem will be judged on CodeForces ...
- Leetcode 68.文本左右对齐
文本左右对齐 给定一个单词数组和一个长度 maxWidth,重新排版单词,使其成为每行恰好有 maxWidth 个字符,且左右两端对齐的文本. 你应该使用"贪心算法"来放置给定的单 ...
- mybatis源码阅读-执行一个sql的流程(九)
图解 图片来源:https://my.oschina.net/zudajun/blog/670373 Mapper接口调用原理 我们整合成Spring 直接使用Mapper就能执行对应的sql 表现 ...