JS和函数式语言的三特性


Posted in Javascript onMarch 05, 2014

首先要有一个概念:并不是一个语言支持函数,这个语言就可以叫做“函数式语言”。函数式语言中的函数(function),除了能被调用之外,还具有一些其他性质。有以下三点:
1. 函数是运算元
2. 在函数内保存数据
3. 函数内的运算对函数外无副作用
一、函数是运算元
普通的函数调用时,可以抽象的理解为:函数就是一个运算符,传入的参数是运算元;
但当JavaScript中的函数作为另一个函数的参数使用时,是传递引用的,这个“传入参数”就可以被理解为是一个运算元。由此的结论是,(作为“传入参数”的)函数具有运算元的含义,“函数参数”与普通参数并没有什么不同。

二、在函数内保存数据
在命令式语言中,函数内部的私有变量(局部变量)是不能被保存的。从程序的执行方式上来讲,局部变量在栈上分配,在函数执行结束后,所占用的栈被释放。因此函数内的数据不可能被保存。
在JavaScript的函数中,函数内的私有变量可以被修改,而且当再次“进入”到该函数内部时,这个被修改的状态仍将持续。下面的例子说明了这个特性:

  var set,get;
  function MyFunc(){
      var value = 100;
      function set_value(v){
          value = v;
      }
      function get_value(){
          return value;
      }
      set = set_value;
      get = get_value;
  }  
  MyFunc();
  console.log(get()); //100
  set(300);
  console.log(get()); //300

显而易见的一个好处是,如果一个数据能够在函数内持续保存,那么该函数(作为构造器)赋给实例时就可以使用这些数据进行运算;而在多个实例之间,由于数据存在于不同的闭包中,由此相互不会产生影响。
以面向对象的术语来解释,就是说不同的实例有各自的私有数据(复制自某个公共的数据)。下面的例子说明了这个特性:
  function MyObject(){
      var value = 100;
      this.setValue = function(){
          value = v;
      }
      this.showValue = function(){
          console.log(value);
      }
  }
  var obj1 = new MyObject();
  var obj2 = new MyObject();
  obj2.setValue(300);
  obj1.showValue(); //100;

三、函数内的运算对函数外无副作用
这一特性的含义在于:
* 函数使用入口参数进行运算,而不修改它(作为值参数而不是变量参数使用)
* 在运算过程中不会修改函数外部的其他数据的值(例如全局变量)
* 运算结束后通过“函数返回”向外部系统传值

这样的函数在运算过程中对外部系统是无副作用的。然而我们注意到,JavaScript允许在函数内部引用和修改全局变量,甚至可以声明全局变量。这一点其实是破坏它的函数式特性的。
除此之外,JavaScript也允许在函数内修改对象和数组成员————这些成员应该由对象方法而非对象系统外的其他函数来修改。
所以:JavaScript这项特性只能通过开发人员的编程习惯来保证。

Javascript 相关文章推荐
jQuery 1.2.x 升? 1.3.x 注意事项
May 06 Javascript
深入理解JavaScript系列(2) 揭秘命名函数表达式
Jan 15 Javascript
JavaScript NaN和Infinity特殊值 [译]
Sep 20 Javascript
使用JavaScript和CSS实现文本隔行换色的方法
Nov 04 Javascript
JS触发服务器控件的单击事件(详解)
Aug 06 Javascript
JS继承之借用构造函数继承和组合继承
Sep 07 Javascript
js入门之Function函数的使用方法【新手必看】
Nov 22 Javascript
axios 处理 302 状态码的解决方法
Apr 10 Javascript
angularJs复选框checkbox选中进行ng-show显示隐藏的方法
Oct 08 Javascript
Vue中的验证登录状态的实现方法
Mar 09 Javascript
TypeScript之调用栈的实现
Dec 31 Javascript
javascript实现简易数码时钟
Mar 30 Javascript
jquery 使用简明教程
Mar 05 #Javascript
jquery form表单序列化为对象的示例代码
Mar 05 #Javascript
js对文章内容进行分页示例代码
Mar 05 #Javascript
JavaScript获取XML数据附示例截图
Mar 05 #Javascript
js通过八个点 拖动改变div大小的实现方法
Mar 05 #Javascript
javascript日期格式化示例分享
Mar 05 #Javascript
javascript避免数字计算精度误差的方法详解
Mar 05 #Javascript
You might like
谈谈PHP语法(3)
2006/10/09 PHP
php中让上传的文件大小在上传前就受限制的两种解决方法
2013/06/24 PHP
codeigniter框架批量插入数据
2014/01/09 PHP
WordPress主题中添加文章列表页页码导航的PHP代码实例
2015/12/22 PHP
java模拟PHP的pack和unpack类
2016/04/13 PHP
Laravel框架中VerifyCsrfToken报错问题的解决
2017/08/30 PHP
PHP实现生成模糊图片的方法示例
2017/12/21 PHP
php提高脚本性能的4个技巧
2020/08/18 PHP
JavaScript中this关键字使用方法详解
2007/03/08 Javascript
Jquery下attr和removeAttr的使用方法
2010/12/28 Javascript
jquery 操作表格实现代码(多种操作打包)
2011/03/20 Javascript
javascript设计模式 封装和信息隐藏(上)
2012/07/24 Javascript
使用iframe window的scroll方法控制iframe页面滚动
2014/03/05 Javascript
javascript跨域的4种方法和原理详解
2014/04/08 Javascript
浅谈javascript中call()、apply()、bind()的用法
2015/04/20 Javascript
如何解决谷歌浏览器下jquery无法获取图片的尺寸
2015/09/10 Javascript
jquery使用Cookie和JSON记录用户最近浏览历史
2016/04/19 Javascript
全面了解函数声明与函数表达式、变量提升
2016/08/09 Javascript
javascript比较语义化版本号的实现代码
2016/09/09 Javascript
js实现符合国情的日期插件详解
2017/01/19 Javascript
JavaScript实现开关等效果
2017/09/08 Javascript
JS实现点击循环切换显示内容的方法
2017/10/19 Javascript
Node.js中DNS模块学习总结
2018/02/28 Javascript
微信小程序自定义组件封装及父子间组件传值的方法
2018/08/28 Javascript
微信小程序如何使用云开发
2019/05/17 Javascript
python pickle 和 shelve模块的用法
2013/09/16 Python
python网络编程实例简析
2014/09/26 Python
python实现图片批量压缩程序
2018/07/23 Python
keras 权重保存和权重载入方式
2020/05/21 Python
python 利用百度API识别图片文字(多线程版)
2020/12/14 Python
欧洲领先的电子和电信零售商和服务提供商:Currys PC World Business
2017/12/05 全球购物
大学生饮食连锁店创业计划书
2014/01/17 职场文书
应聘英语教师求职信
2014/04/24 职场文书
公司人事专员岗位职责
2014/08/11 职场文书
预备党员群众意见
2015/06/01 职场文书
一篇文章带你掌握SQLite3基本用法
2022/06/14 数据库