【废弃】【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 () {-};使 ...
随机推荐
- Android 7.0系统代码调用安装apk时报错FileUriExposedException完美解决
项目更新遇到问题 Android项目开发中经常遇到下载更新的需求,以前调用系统安装器执行安装操作代码如下: Intent intent = new Intent(); intent.setActi ...
- React-native SyntaxError: Unexpected token ...
更新 node.js 版本到 v6.11.1. https://github.com/facebook/react-native/issues/15040
- 洛谷——P1972 [SDOI2009]HH的项链(线段树)
P1972 [SDOI2009]HH的项链 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断地收集新的 ...
- UVA - 1620 Lazy Susan(逆序数)
题目: 把1~n(n≤500)放到一个圆盘里,每个数恰好出现一次.每次可以选4个连续的数字翻转顺序.问能不能变成1.2.3....n的顺序. 思路: 这样的题的规律真的是一点都不好推,看了网上的博客知 ...
- Linux 中设置 MySQL 字符集为 UTF-8
(1)查看 MySQL 字符集 登录 mysql:mysql -u root -p 查询 mysql 字符集:mysql> show variables like 'chara%'; 说明:将 ...
- linux内核开发程序风格
变量命名法 这里是linux不是windows,所以匈牙利命名法是不允许使用的,在内核中,局部变量只要可以明确表达自己的意思,可以使用idx,i这种名字的id, 全局函数和变量需要有表达性的名字例如g ...
- Go:闭包
闭包就是一个函数和与其相关的引用环境组合的一个整体(实体). package main import "fmt" func add() func(int) int { i := 0 ...
- linux nethogs-终端下的网络流量监控工具
推荐:更多linux 性能监测与优化 关注:linux命令大全 有很多适用于Linux系统的开源网络监视工具.比如说,你可以用命令iftop来检查带宽使用情况.netstat用来查看接口统计报告,还有 ...
- 第十五节:Web爬虫之selenium动态渲染爬取
selenium是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.支持的浏览器包括IE(7, 8, 9, 10, 11),Mozilla Firef ...
- [luoguP2904] [USACO08MAR]跨河River Crossing(DP)
传送门 f[i] 表示送前 i 头牛过去再回来的最短时间 f[i] = min(f[i], f[j] + sum[i - j] + m) (0 <= j < i) ——代码 #includ ...