首页 > 其他分享 >立即执行函数在前端国际化方案中的应用

立即执行函数在前端国际化方案中的应用

时间:2023-02-20 23:44:25浏览次数:63  
标签:function 国际化 函数 前端 object js 立即 执行

说起国际化,开发过跨区域网页的小伙伴应该都遇到过。我们的网页需要配置多套语言,方便用户进行切换。

 

本文就以 React 为例,介绍其中一种实现方案,并学习一下其中的知识点。

 

一种国际化方案

 

方案是这样的:

  1. 为多套语言创建对应的 object,并 export 出去

  2. 通过 js 立即执行函数,加载选定语言 js 文件中的 object,并 export 出去

  3. 项目中引入第 2 步中 export 的 object,直接使用即可

 

图示(假设支持中英两种语言):

 

 

加上业务文件引用后,全景图如下:

 

 

可以看出来,其实 lang/index.js 文件起到了一种「接口」的作用,帮我们屏蔽了语言类型。在实际情况中,我们可以让浏览器自动获取特定 cookie,并借助 js 立即执行函数,将对应的语言包 object 暴露出去,此时业务代码中引用的地方就可以自动获取到对应的语言,进而展示:

 

 

你看,这种方案是不是超级简单?

下面我们来看看其中涉及到的一个重要知识点:立即执行函数。


 

什么是立即执行函数?

 

  • 首先,它是一个匿名函数;

  • 其次,它在声明后会被立即执行;

  • 最后,使用圆括号加以调用。

这就是它的最简定义了。

我们把上面用到的代码简化一下:

 

 

在 js 中,function 这个关键字,既可以当做语句,也可以当做表达式,上面立即执行函数的写法,其实就是把 function 当作表达式了。

插入一个关键知识:

 

 

如何让 function 当作表达式呢?我们看下 JS 引擎的规定:如果 function 出现在行首,则解析成语句。对于语句来说,不能以圆括号结尾,否则报错。

所以,只要想办法让 function 被解析为表达式,就可以得到 立即执行函数的多种写法,我们总结一下:

 

 

​注 1:图中展示的是无参形式,也可以存在形参和实参​。

可以看出,不同形式的写法,具有不同的返回值。在本文的国际化例子中,我们在方法体中 return 了语言包 object,并不关心函数的返回值,所以可以随意使用任意写法:

 

 

那么问题来了,立即执行函数有啥用武之地?

 

立即执行函数的几大作用

 

  • 使用匿名函数,无需为函数命名,避免污染全局变量

  • 它的内部形成了一个单独的作用域,可以封装外部无法读取的私有变量

 

第一点很好理解,我们看看第二点在说什么。

 

继续用国际化的例子说明,我们其实把 cookie 封闭在了 lang/index.js 文件中,外部文件是无法读取到这个 LocaleCode 这个私有变量的(其实也根本不关心),这就是所谓的封装带来的安全性。

 

扩展到高阶函数

作为 js 中的一等公民,函数不仅拥有一切传统函数的使用方式(声明和调用),而且可以做到像简单值一样赋值、传参、返回。所以我们完全可以让立即函数返回一个函数​,​举个例子:

 

 

看一下执行结果,就很好理解了:

 

 

所以,你可以尽情把高阶函数的能力带到立即执行函数中​。

 

一句话总结:立即执行函数的作用域封闭能力可以很优雅地实现一些现实业务诉求​,还可以结合高阶函数实现更为复杂的功能,希望大家都能灵活掌握并运用​。

 

最后​,本文部分内容参考了文章:https://www.jianshu.com/p/b10b6e93ddec​,推荐一读。​

TRANSLATE with x English
Arabic Hebrew Polish
Bulgarian Hindi Portuguese
Catalan Hmong Daw Romanian
Chinese Simplified Hungarian Russian
Chinese Traditional Indonesian Slovak
Czech Italian Slovenian
Danish Japanese Spanish
Dutch Klingon Swedish
English Korean Thai
Estonian Latvian Turkish
Finnish Lithuanian Ukrainian
French Malay Urdu
German Maltese Vietnamese
Greek Norwegian Welsh
Haitian Creole Persian  
  TRANSLATE with COPY THE URL BELOW Back EMBED THE SNIPPET BELOW IN YOUR SITE Enable collaborative features and customize widget: Bing Webmaster Portal Back

标签:function,国际化,函数,前端,object,js,立即,执行
From: https://www.cnblogs.com/xiaoxi666/p/17139449.html

相关文章

  • 关于一维数组传入函数的使用 //西电oj214题字符统计
    #include<stdio.h>voidcount(charstr[],intnum[]){//形参用【】,传递数组首地址后可以直接正常用数组str[i] inti; for(i=0;str[i]!=0;i++){ if(str[i]>=65&&str[......
  • 从页面仔到工程师,前端到底在发挥什么价值
    玉伯在前端圈子里摸爬滚打十几年,他对前端价值的理解是什么样的?在他眼里,前端到底是一个怎样的岗位?我们带着这样的问题向他提问。支付宝体验技术部是前端同学最希望加入的团队......
  • 前端获取文件后缀名称
    getFileExtension=(fileName)=>{returnfileName.substring(fileName.lastIndexOf('.')+1)}constisExcel=(fileName)=>{constfileExt=getFileExten......
  • 前端Blob数据流转JSON格式
    blobToJson=(blobData)=>{returnnewPromise((resolve,reject)=>{constreader:any=newFileReader()letjsonData:anyreader.readAsText(b......
  • 前端从接口的header中获取filename
    getFileNameFromHeaders=(headers)=>{constdisposition=headers['content-disposition']letfileName='未命名'try{fileName=disposition.split......
  • 前端工程师面试题10条必会笔试题
    布局左边20%中间自适应右边200px不能用定位答案:圣杯布局/双飞翼布局或者flex什么叫优雅降级和渐进增强?渐进增强progressiveenhancement:针对低版本浏览器进行......
  • 模拟实现字符串相关函数
    //#define_CRT_SECURE_NO_WARNINGS//#include<stdio.h>//#include<string.h>////如何写出好(易于调试)的代码?//1.代码运行正常//2.bug很少//3.效率高//4.可读性......
  • 《数学》三角函数公式汇总
    01-定义式三角函数公式是数学中属于初等函数中的超越函数的一类函数公式。它们的本质是任意角的集合与一个比值的集合的变量之间的映射,通常的三角函数是在平面直角坐标系......
  • 系统化学习前端之HTML篇(02)
    写在前面前面已经梳理了HTML的基础标签使用,常规开发的话,基础标签已经完全满足日常工作了。但是,我们往往不满足于简单的页面,还需要提升,这个提升包括了页面SEO的提升、页面......
  • 三角函数 / trigonometry
    基本知识点primary:$\sin\theta=\frac{\text{opposite}}{\text{hypotenuse}},\cos\theta=\frac{\text{adjacent}}{\text{hypotenuse}},\tan\theta=\frac{\text{opposite}......