曾经我一度在寻找JS的替代语言,尝试过CoffeeScript/TypeScript/Dart(都是浅尝)。不为什么原因,而是当你写的越多的JS,越觉得JS很多时候显得很操蛋。好在ES2015Babel出来了,也让我终止了寻找替代方案,安心的停留在了JavaScript本身。

我并没有非常丰厚的多语言编程经验,但也有一丝想法,对于JavaScript来说。

Array增加firstlast方法
let arr = [1, 2, 3];
arr.first(); //1
arr.last(); //3

当然用arr[0]arr[arr.length-1]也能够实现相同的效果,不过方案显得不够优雅


[n...m]快速生成从nm的数字数组(可用于简洁的循环)
let arr = [0...9];
//等同于
let arr2 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; [0...9].map(n => console.log(n));

提供快速检测对象属性是否存在的方法Object.isSet,这样就不必去做嵌套式的判断语句了,也不用担心抛出异常
let a = {};

if (Object.isSet(a.b.c.d)) {
//现在a.b.c.d能够安全的调用
} //现在只能这样判断.d能否被安全调用
if (a && a.b && a.b.c && a.b.c.d) {
//现在a.b.c.d能够被安全的调用
}

Date对象的toString方法提供输出指定格式的日期时间字符串
let d = new Date();

d.toString('yyyy-MM-dd'); //2016-01-01
//hh 12小时制 HH 24小时制
d.toString('hh:mm:ss'); //09:21:12
d.toString('HH:mm:ss'); //21:21:12

Date对象提供对年、月、日、分、秒的增减方法
let d = new Date();
//2016-01-01 09:20:20 d.years(1); //2017-01-01 09:20:20
d.years(-1); //2015-01-01 09:20:20 d.months(1); //2016-02-01 09:20:20
d.months(-1); //2015-12-01 09:20:20 d.days(1); //2016-01-02 09:20:20
d.days(-1); //2015-12-31 09:20:20 d.minutes(1); //2016-01-01 09:21:20
d.minutes(-1); //2016-01-01 09:19:20 d.seconds(1); //2016-01-01 09:20:21
d.seconds(-1); //2016-01-01 09:20:19

我认为JS还可以改进的点的更多相关文章

  1. ul+js模拟select+改进

    html: <div class="select_box"> <input type="text" value="还款方式" ...

  2. 使用Node.js还可以发邮件

    前言 今天,我们给大家开发一个小效果.篇幅比较短,主要给大家展示效果.实战 首先我们初始化一个Node项目 npm init -y 创建一个app.js文件 'use strict'; const n ...

  3. [ JS 进阶 ] 如何改进代码性能 (3)

    原文链接 总结一下 1.减少操作dom的次数 2.需要多次使用某全局变量的时候,将其赋给一个局部变量,避免重复查找 3.优化循环 4.多用逗号和直接赋值的方式来var,减少工厂方式和构造函数方式创建对 ...

  4. JS做的类似腾讯专题图片播放器,大家可以一起来改进!

    我是一个应届生,来公司不久,根据需求,网站需要一个专题图片轮播的页面.网上确实有很多现成的插件,但是,作为一个JS还不是很牛的应届生,我决定自己写一个! 话说忽然想到做个这个还真不容易,一时思绪理不清 ...

  5. Vue.js:轻量高效的前端组件化方案

    转发一篇尤老师对vue.js的介绍,了解vue.js的来龙去脉.不过现在已经是2.0了,也有添加一些新的东西,当然有些东西也改了. Vue.js:轻量高效的前端组件化方案 Vue.js 是我在2014 ...

  6. js模块化历程

    这是一篇关于js模块化历程的长长的流水账,记录js模块化思想的诞生与变迁,展望ES6模块化标准的未来.经历过这段历史的人或许会感到沧桑,没经历过的人也应该知道这段历史. 无模块时代 在ajax还未提出 ...

  7. js 模块化历程

    作者:吕大豹 网址:http://www.cnblogs.com/lvdabao/p/js-modules-develop.html 这是一篇关于js模块化历程的长长的流水账,记录js模块化思想的诞生 ...

  8. Vue.js:轻量高效的前端组件化方案(转载)

    摘要:Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统.在前端纷繁复杂的生态中,Vue.js有幸受到一定程度的关注,目前在GitHub上已经有5000+的star.本文将从各方面对Vue ...

  9. Ext JS 5的声明式事件监听

    在前文<在Ext JS 5使用ViewControllers>中,简单的介绍了Ext JS 5的一项重要改进——声明式事件监听.在本文,将深度探讨如何使用声明式事件监听啦简化应用程序的视图 ...

随机推荐

  1. 通过一个demo了解Redux

    TodoList小demo 效果展示 项目地址 (单向)数据流 数据流是我们的行为与响应的抽象:使用数据流能帮我们明确了行为对应的响应,这和react的状态可预测的思想是不谋而合的. 常见的数据流框架 ...

  2. 【原】FMDB源码阅读(一)

    [原]FMDB源码阅读(一) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 说实话,之前的SDWebImage和AFNetworking这两个组件我还是使用过的,但是对于 ...

  3. Unity 序列化

    Script Serialization http://docs.unity3d.com/Manual/script-Serialization.html 自定义序列化及例子: http://docs ...

  4. 了解PHP中的Array数组和foreach

    1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组    . 2.例子:一般的数组 这里,我 ...

  5. HTML简单入门内容

    常用属性: Width=宽度 Height=高度 Size=大小 Color=颜色 Align=布局方向,值包括(top,bottom,left,right,center)上,下,左,右,中. Bor ...

  6. 常用 meta 整理

    <!-- 针对手持设备优化,主要是针对一些老的不识别viewport的浏览器,比如黑莓 --> <meta name="HandheldFriendly" con ...

  7. 项目管理_FindBugs的使用

    本章将讲述如何在Myeclipse下,使用FindBugs,静态分析工具,无需开发人员费劲就能找出代码中已有的缺陷. 一:Myeclipse下如何安装FindBugs插件 1:FindBugs插件下载 ...

  8. 《Note --- Unreal --- MemPro (CONTINUE... ...)》

    Mem pro 是一个主要集成内存泄露检测的工具,其具有自身的源码和GUI,在GUI中利用"Launch" button进行加载自己待检测的application,目前支持的平台为 ...

  9. thinkphp-无限分类下根据任意部门获取顶级部门ID

    根据所得到的部门编号获取顶级部门ID: 参数 - department_id 表格组织架构: tab_departments department_id parent_id name 1 1 顶级 2 ...

  10. .Net中的AOP系列之《间接调用——拦截方法》

    返回<.Net中的AOP>系列学习总目录 本篇目录 方法拦截 PostSharp方法拦截 Castle DynamicProxy方法拦截 现实案例--数据事务 现实案例--线程 .Net线 ...