JavaScript轻松创建级联函数的方法示例


Posted in Javascript onFebruary 10, 2017

一、级联函数是什么?

在一行代码上,调用一个接一个的方法。这种技术在 JQuery 或者其他 JavaScript 库中是非常常见的。
代码如下:

$('#myDiv').fadeOut().html('帅哥, 你好!').fadeIn();

或者:

myStr1.replace('k', 'R').toUpperCase().substr(0,4);

这种代码让我们能像阅读文字一样来阅读代码,不仅简洁,可读性强更便于维护,提高开发效率。

那怎么用呢?

要使用级联函数,我们必须在每个函数中返回 this 对象(也就是后面方法中操作的对象)。现在我们开始创建个级联函数:

var usresData = [
 {firstName: 'Zhang', lastName: 'San', email: '111@qq.com', id: 102},
 {firstName: 'Li', lastName: 'Si', email: '222@qq.com', id: 103},
 {firstName: 'Wang', lastName: 'Wu', email: '333@qq.com', id: 105}
];

function getCaseName(str) {
 return str.replace(/\w\S*/g, function(txt){
  return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();
 })
}

接下来我们定义个包含级联函数的对象:

var userController = {
 currentUser = '',
 findUser = function (userEmail) {
  var arrayLength = usersData.length, i;
  for (i = arrayLength - 1; i >= 0; i--) {
   if (usersData[i].email === userEmail) {
    this.currentUser = usersData[i];
    break;
   }
  }
  return this;
 },
 formatName: function () {
  if (this.currentUser) {
   this.currentUser.fullName = getCaseName(this.currentUser.firstName) + ' ' + getCaseName(this.currentUser.lastName);
  }
  return this;
 },
 createLayout: function () {
  if (this.currentUser) {
   this.currentUser.viewData = '<h2>成员: ' + this.currentUser.fullName + '</h2>'​
   + '<p>ID: ' + this.currentUser.id + '</p>' + '<p>Email: ' + this.currentUser.email + '</p>';
  }
  return this;
 },
 displayUser: function () {
  if (!this.currentUser) return;
  $('.members-wrapper').append(this.currentUser.viewData);
 }
}

定义完了级联函数,我们调用的时候就会非常的优雅了:

userController.findUser('111@qq.com').formatName().createLayout().displayUser();

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
javascript高亮效果的二种实现方法
Sep 14 Javascript
实现png图片和png背景透明(支持多浏览器)的方法
Sep 08 Javascript
JavaScript访问样式表代码
Oct 15 Javascript
在一个js文件里远程调用jquery.js会在ie8下的一个奇怪问题
Nov 28 Javascript
javascript学习笔记(四)function函数部分
Sep 30 Javascript
JavaScript调用浏览器打印功能实例分析
Jul 17 Javascript
基于AngularJS+HTML+Groovy实现登录功能
Feb 17 Javascript
浅谈js的异步执行
Oct 18 Javascript
在Vuex使用dispatch和commit来调用mutations的区别详解
Sep 18 Javascript
8个有意思的JavaScript面试题
Jul 30 Javascript
Layui表格监听行单双击事件讲解
Nov 14 Javascript
在vue中使用防抖函数组件操作
Jul 26 Javascript
JS实现的数字格式化功能示例
Feb 10 #Javascript
Vue.js 2.0窥探之Virtual DOM到底是什么?
Feb 10 #Javascript
BootStrap Datepicker 插件修改为默认中文的实现方法
Feb 10 #Javascript
BootStrap Datetimepicker 汉化的实现代码
Feb 10 #Javascript
解决URL地址中的中文乱码问题的办法
Feb 10 #Javascript
tablesorter.js表格排序使用方法(支持中文排序)
Feb 10 #Javascript
jquery.tableSort.js表格排序插件使用方法详解
Aug 12 #Javascript
You might like
全国FM电台频率大全 - 17 湖北省
2020/03/11 无线电
php 上传功能实例代码
2010/04/13 PHP
php获取bing每日壁纸示例分享
2014/02/25 PHP
2020最新版 PhpStudy V8.1版本下载安装使用详解
2020/10/30 PHP
用Javscript实现表单复选框的全选功能
2007/05/25 Javascript
AJAX使用了UpdatePanel后无法使用alert弹出脚本
2010/04/02 Javascript
Wordpress ThickBox 添加“查看原图”效果代码
2010/12/11 Javascript
推荐10个超棒的jQuery工具提示插件
2011/10/11 Javascript
构造函数+原型模式构造js自定义对象(最通用)
2014/05/12 Javascript
NodeJs中的VM模块详解
2015/05/06 NodeJs
Angular懒加载机制刷新后无法回退的快速解决方法
2016/08/30 Javascript
JavaScript实现星星等级评价功能
2017/03/22 Javascript
BootStrap Table 后台数据绑定、特殊列处理、排序功能
2017/05/27 Javascript
js 获取元素的具体样式信息getcss(实例讲解)
2017/07/05 Javascript
JS正则表达式完美实现身份证校验功能
2017/10/18 Javascript
微信小程序选择图片和放大预览图片功能
2017/11/02 Javascript
vue对storejs获取的数据进行处理时遇到的几种问题小结
2018/03/20 Javascript
详解如何在Vue项目中发送jsonp请求
2019/10/25 Javascript
JS实现iframe中子父页面跨域通讯的方法分析
2020/03/10 Javascript
js实现贪吃蛇小游戏(加墙)
2020/07/31 Javascript
[44:15]DOTA2上海特级锦标赛主赛事日 - 5 败者组决赛Liquid VS EG第二局
2016/03/06 DOTA
Python中read()、readline()和readlines()三者间的区别和用法
2017/07/30 Python
pandas的object对象转时间对象的方法
2018/04/11 Python
python 输入一个数n,求n个数求乘或求和的实例
2018/11/13 Python
python处理DICOM并计算三维模型体积
2019/02/26 Python
keras实现VGG16 CIFAR10数据集方式
2020/07/07 Python
浅谈CSS3 动画卡顿解决方案
2019/01/02 HTML / CSS
入党自我鉴定范文
2013/10/04 职场文书
员工培训邀请函
2014/02/02 职场文书
卖车协议书
2014/04/21 职场文书
农行心得体会
2014/09/02 职场文书
2015年大学团支部工作总结
2015/05/13 职场文书
2015高中教师个人工作总结
2015/07/21 职场文书
完美处理python与anaconda环境变量的冲突问题
2021/04/07 Python
MySQL Server层四个日志的实现
2022/03/31 MySQL
Python 文字识别
2022/05/11 Python