Javascript 的最佳实现方法总结(一)

Javascript 的最佳实现方法总结

本文将主要针对 Javascript 来总结一些常用的实现方法,有的是根据自身实践总结出来的经验,有的是在逛别人的博客和技术分享时候得到的启发,全部都会慢慢搬到这里,也欢迎有更多的人来提供你们的实现方式,大家互相交流。作为一个刚刚毕业的前端小白,也希望的各位老司机能为我指出不足。本文也将不定期更新!

1. 生成随机字符串的实现

还记得校招的时候,以为自己面的是前端岗,应该主要就是考察布局基础、Javascript基础、常用框架理解、Node.js、前端性能优化等等知识,但是没想到坐下来面试官就让我写一个随机字符串生成器,当时也写出来了,不过显得十分笨重,下面是我在阅读别人代码里面看到的比较不错的实现方式,希望可以对工作和面试的人有用。

const random_str = function(length) {
    const chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890'
    let str = ''
    for(let i = 0; i <length; i++) {
        str += chars.charAt(Math.floor(Math.random() * chars.length))
    }
    return str
}

直接通过对输出字符串增加字符,要比使用数组方法好一些,而且这样生成一个指定位数的随机字符串,重复几率也会很低,并且随着length增大,重复几率降低。

2. 前端获取服务端时间

这个是在逛博客的时候看到的黑科技,简单粗暴!

const request = new XMLHttpRequest()
request.get('GET', location, false)
request.send(null)
console.log(req.getResponseHeader('Date'))

3. 检测类型

还记得以前去面试的时候,面试官问我怎么判断一个变量的类型,我张口就是typeof,现在想想真想给自己一个大耳刮子,实际上,typeof只能用来检测基本类型,我们举个例子:

typeof 20 //'number'
typeof 'hey man' //'string'
typeof true //'boolean'
typeof undefined //'undefined'
typeof Symbol() //'symbol'
typeof {} //'object'
typeof [] //'object'
typeof Function() //'function'

我们可以看到,基本类型使用typeof就可以检测出变量类型,可是在引用类型里,对象和数组输出的值都是object,函数则是输出function。对于自定义类型和原生的引用类型,一般使用instanceof进行判断。比如:

let obj = {}
let arr = []
obj instanceof Object //true
obj instanceof Array //false
arr instanceof Array // true

但是有时候情况往往不是这么简单。比如如果你想检测 iframe 里面的属性值的话,基本上是不可能的。因为检测的前提要求是在同一个全局作用于下。所以为了能够正常检测一些值的类型(排除在 iframe 的情况)。那有没有什么万能的方法呢?确实有,你可以使用调用toString()的方法,得到相关的类型。就像这样:

let value = new FormData()
console.log(Object.prototype.toString.call(value))
//'[object FormData]'

由此,也就可以得出一个通用的检测类型方法,基本上可以返回所有的类型。代码如下:

const getType = function(value) {
    return Object.prototype.toString.call(value).match(/\s{1}(\w+)/)[1]
}

4. 前端压缩图片

一年前找实习的时候被问到前端性能优化,就有提到前端压缩图片,那么要怎么压缩?为什么要压缩?对于压缩图片的需求一般会出现在上传图片(尤其是移动端)功能里,比如微信发朋友圈、QQ空间发说说(现在多了一个发送原图的按钮)的时候,就对上传的图片进行过压缩。

毕竟现在的手机硬件越来越流弊,随便一拍就是好几M,无论是用3G/4G还是Wifi上传起来都比较费劲,而且也比较浪费流量,一般只需要100+M就已经差不多了。因此,在用户选择好需要上传的图片之后,在客户端需要进行处理,将图片压缩好再上传到服务器进行下一步处理。

图片压缩的原理大同小异,自己也试着写过一些,都不理想,后来看到一篇博客分享了关于前端压缩图片的一个插件localResizeIMG,觉得很好用,就拿来分享了。引用localResizeIMG官方文档的原话:

基本原理是通过canvas渲染图片,再通过 toDataURL 方法压缩保存为 base64 字符串(能够编译为jpg格式的图片)。

那么怎么用呢?也很简单,传入照片(可以是file对象也可以直接传入图片路径),然后设置好自己想要的分辨率(就是最大widthheight是多少px),接着设置个图片质量,再来一个Promise风格的callback差不多就行了,最后把压缩完的base64作为参数传进callback。作者还很贴心的把照片base64编码的长度也传参进来了,方便后端校验图片是否上传完整。示例如下:

<input onchange="upload().bind(this)" type="file" accept="image/*" />
function upload() {
    lrz(this.files[0])
        .then(rst => {
            // 处理成功会执行
        })
        .catch(err => {
            // 处理失败会执行
        })
        .always(() => {
            // 不管是成功失败,都会执行
        })
})

再给个传送门:https://github.com/think2011/localResizeIMG


暂时先总结这四个,有需要的同学可以先看着,等过两天还会给大家带来更多的分享,有的是来自我自己,有的是我在逛技术圈的时候看到比较不错的实现方式,有什么不对的地方欢迎指出来,有什么更好的实现方式也可以提出来,大家一起交流一起进步!当然点个赞和关注是最好的啦!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,458评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,454评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,171评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,062评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,440评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,661评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,906评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,609评论 0 200
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,379评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,600评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,085评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,409评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,072评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,088评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,860评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,704评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,608评论 2 270

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,569评论 25 707
  • 文档: 文档中的键是有序的。{'a': 'b', 'c': 'd'} 和 {'c': 'd', 'a': 'b'...
    kker阅读 136评论 0 0
  • 第一次听说一个人叫“流氓”我们嘲笑了他很久很久。 第二次他还是这样介绍自己,我们知道了他叫流芒。 第三次听到他介绍...
    已经离去阅读 756评论 2 10
  • 你的生活或许不是你想要的,但是你自找的。 这句话值得商榷却不无道理,我们怎样的生活,怎样的工作,都是我们的选择。无...
    Doris_KK8阅读 902评论 2 9
  • 说来话长,其实在2015年北京家庭教育指导师培训中,我就听说过唐老师,据说他是一位高人。然后就在微信群里添加了唐老...
    Lisa2021阅读 300评论 0 0