javascript的包,js文件包

怎样写一个能同时用于Node和浏览器的JavaScript包

对于浏览器来说,这很简单:我们只需要使用自带的 btoa 函数:

目前成都创新互联已为上千的企业提供了网站建设、域名、网络空间、网站托管、服务器租用、企业网站设计、原州网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

module.exports = function (string) {

return btoa(string);

};

然而在 Node 里并没有 btoa 函数。因此,作为替代,我们需要自己创建一个 Buffer ,然后在上面调用 buffer.toString() :

module.exports = function (string) {

return Buffer.from(string, 'binary').toString('base64');

};

对于一个字符串,这两者都应提供其正确的 base64 编码版本,比如:

var b64encode = require('base64-encode-string');

b64encode('foo'); // Zm9v

b64encode('foobar'); // Zm9vYmFy

现在我们只需要一些方法来检测我们究竟是在浏览器上运行还是在 Node 上,好让我们能保证使用正确的版本。Browserify 和 Webpack 都定义了一个叫 process.browser 的字段,它会返回 true (译者注:即浏览器环境下),然而在 Node 上这个字段返回 false 。所以我们只需要简单地:

if (process.browser) {

module.exports = function (string) {

return btoa(string);

};

} else {

module.exports = function (string) {

return Buffer.from(string, 'binary').toString('base64');

};

}

现在我们只需要把我们的文件命名为 index.js ,键入 npm publish ,我们就完成了,对不对?好的吧,这个方法有效,但不幸的是,这种实现有一个巨大的性能问题。

NodeJS常用包介绍--cmd-shim

V2.0.2

npm install cmd-shim

用于创建不同终端可执行脚本

执行之后会在 to 参数指定的目录中出现两个可执行脚本, command-name.cmd 和 command-name

cli.js

index.js

执行 index.js 之后,会在本目录下出现 cli.cmd 和 cli 两个文件,可直接在相应系统上直接执行。

javascript的闭包是什么意思?有什么用?

一、什么是闭包?\x0d\x0a“官方”的解释是:所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。\x0d\x0a相信很少有人能直接看懂这句话,因为他描述的太学术。我想用如何在Javascript中创建一个闭包来告诉你什么是闭包,因为跳过闭包的创建过程直接理解闭包的定义是非常困难的。看下面这段代码: \x0d\x0afunction a(){\x0d\x0a var i=0;\x0d\x0a function b(){\x0d\x0a alert(++i);\x0d\x0a }\x0d\x0a return b;\x0d\x0a}\x0d\x0avar c = a();\x0d\x0ac();\x0d\x0a这段代码有两个特点:\x0d\x0a1、函数b嵌套在函数a内部;\x0d\x0a2、函数a返回函数b。\x0d\x0a这样在执行完var c=a()后,变量c实际上是指向了函数b,再执行c()后就会弹出一个窗口显示i的值(第一次为1)。这段代码其实就创建了一个闭包,为什么?因为函数a外的变量c引用了函数a内的函数b,就是说:\x0d\x0a\x0d\x0a当函数a的内部函数b被函数a外的一个变量引用的时候,就创建了一个闭包。\x0d\x0a\x0d\x0a我猜想你一定还是不理解闭包,因为你不知道闭包有什么作用,下面让我们继续探索。\x0d\x0a\x0d\x0a二、闭包有什么作用?\x0d\x0a简而言之,闭包的作用就是在a执行完并返回后,闭包使得Javascript的垃圾回收机制GC不会收回a所占用的资源,因为a的内部函数b的执行需要依赖a中的变量。这是对闭包作用的非常直白的描述,不专业也不严谨,但大概意思就是这样,理解闭包需要循序渐进的过程。\x0d\x0a在上面的例子中,由于闭包的存在使得函数a返回后,a中的i始终存在,这样每次执行c(),i都是自加1后alert出i的值。\x0d\x0a\x0d\x0a那 么我们来想象另一种情况,如果a返回的不是函数b,情况就完全不同了。因为a执行完后,b没有被返回给a的外界,只是被a所引用,而此时a也只会被b引 用,因此函数a和b互相引用但又不被外界打扰(被外界引用),函数a和b就会被GC回收。(关于Javascript的垃圾回收机制将在后面详细介绍)\x0d\x0a\x0d\x0a三、闭包内的微观世界\x0d\x0a如 果要更加深入的了解闭包以及函数a和嵌套函数b的关系,我们需要引入另外几个概念:函数的执行环境(excution context)、活动对象(call object)、作用域(scope)、作用域链(scope chain)。以函数a从定义到执行的过程为例阐述这几个概念。\x0d\x0a\x0d\x0a1、当定义函数a的时候,js解释器会将函数a的作用域链(scope chain)设置为定义a时a所在的“环境”,如果a是一个全局函数,则scope chain中只有window对象。\x0d\x0a2、当函数a执行的时候,a会进入相应的执行环境(excution context)。\x0d\x0a3、在创建执行环境的过程中,首先会为a添加一个scope属性,即a的作用域,其值就为第1步中的scope chain。即a.scope=a的作用域链。\x0d\x0a4、然后执行环境会创建一个活动对象(call object)。活动对象也是一个拥有属性的对象,但它不具有原型而且不能通过JavaScript代码直接访问。创建完活动对象后,把活动对象添加到a的作用域链的最顶端。此时a的作用域链包含了两个对象:a的活动对象和window对象。\x0d\x0a5、下一步是在活动对象上添加一个arguments属性,它保存着调用函数a时所传递的参数。\x0d\x0a6、最后把所有函数a的形参和内部的函数b的引用也添加到a的活动对象上。在这一步中,完成了函数b的的定义,因此如同第3步,函数b的作用域链被设置为b所被定义的环境,即a的作用域。\x0d\x0a\x0d\x0a到此,整个函数a从定义到执行的步骤就完成了。此时a返回函数b的引用给c,又函数b的作用域链包含了对函数a的活动对象的引用,也就是说b可以访问到a中定义的所有变量和函数。函数b被c引用,函数b又依赖函数a,因此函数a在返回后不会被GC回收。\x0d\x0a\x0d\x0a当函数b执行的时候亦会像以上步骤一样。因此,执行时b的作用域链包含了3个对象:b的活动对象、a的活动对象和window对象,如下图所示:\x0d\x0a\x0d\x0a如图所示,当在函数b中访问一个变量的时候,搜索顺序是先搜索自身的活动对象,如果存在则返回,如果不存在将继续搜索函数a的活动对象,依 次查找,直到找到为止。如果整个作用域链上都无法找到,则返回undefined。如果函数b存在prototype原型对象,则在查找完自身的活动对象 后先查找自身的原型对象,再继续查找。这就是Javascript中的变量查找机制。\x0d\x0a\x0d\x0a四、闭包的应用场景\x0d\x0a1、保护函数内的变量安全。以最开始的例子为例,函数a中i只有函数b才能访问,而无法通过其他途径访问到,因此保护了i的安全性。\x0d\x0a2、在内存中维持一个变量。依然如前例,由于闭包,函数a中i的一直存在于内存中,因此每次执行c(),都会给i自加1。\x0d\x0a以上两点是闭包最基本的应用场景,很多经典案例都源于此。\x0d\x0a\x0d\x0a五、Javascript的垃圾回收机制\x0d\x0a在Javascript中,如果一个对象不再被引用,那么这个对象就会被GC回收。如果两个对象互相引用,而不再被第3者所引用,那么这两个互相引用的对象也会被回收。因为函数a被b引用,b又被a外的c引用,这就是为什么函数a执行后不会被回收的原因。

javascript 有哪些适合做网络拓扑图形展示的包

最近也在研究这个,Qunee要收费,直接pass,找到一个比较合适的:jTopo(Javascript Topology library)是一款完全基于HTML5 Canvas的关系、拓扑图形化界面开发工具包。

jTopo关注于数据的图形展示,它是面向开发人员的,需要进行二次开发。

使用jTopo很简单,可以快速创建一些关系图、拓扑等相关图形化的展示。只要您的数据之间存在有关联关系,都可以使用jTopo来进行人性化、图形化的展示。

jTopo的目标:1.简单好用 2.灵活扩展 3.轻松开发出类似Visio、在线脑图、UML建模等类似工具 4.为大数据可视化提供解决方案

NodeJS常用包介绍--slash

2.0.0

npm install slash

用于转换 Windows 反斜杠路径转换为正斜杠路径 \ = / 。

正斜杠在 Windows 上是可用的,因为 Windows API 会自动将 / 转换为 \ 。但是如果路径为扩展长度路径(“\?\”前缀),或包含非 Ascii 字符,则不会适用于Windows。

slash(path: string): string

全部源码:

理解javascript闭包

什么是javascript闭包?

javascript允许使用内部函数,内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。

简单的javascript闭包例子:

script

function

f1(){

var

n=999;

nAdd=function(){n+=1}

function

f2(){

alert(n);

}

return

f2;

}

var

result=f1();

result();

//

999

nAdd();

result();

//

1000

/script

在这段代码中,result实际上就是闭包f2函数。它一共运行了两次,第一次的值是999,第二次的值是1000。这证明了,函数f1中的局部变量n一直保存在内存中,并没有在f1调用后被自动清除。

为什么会这样呢?原因就在于f1是f2的父函数,而f2被赋给了一个全局变量,这导致f2始终在内存中,而f2的存在依赖于f1,因此f1也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage

collection)回收。

这段代码中另一个值得注意的地方,就是"nAdd=function(){n+=1}"这一行,首先在nAdd前面没有使用var关键字,因此nAdd是一个全局变量,而不是局部变量。其次,nAdd的值是一个匿名函数(anonymous

function),而这个匿名函数本身也是一个闭包,所以nAdd相当于是一个setter,可以在函数外部对函数内部的局部变量进行操作。

闭包的应用:

var

singleton

=

function

()

{

var

privateVariable;

function

privateFunction(x)

{

...privateVariable...

}

return

{

firstMethod:

function

(a,

b)

{

...privateVariable...

},

secondMethod:

function

(c)

{

...privateFunction()...

}

};

}();

这个单件通过闭包来实现。通过闭包完成了私有的成员和方法的封装。匿名主函数返回一个对象。对象包含了两个方法,方法1可以方法私有变量,方法2访问内部私有函数。需要注意的地方是匿名主函数结束的地方的'()',如果没有这个'()'就不能产生单件。因为匿名函数只能返回了唯一的对象,而且不能被其他地方调用。这个就是利用闭包产生单件的方法。

闭包的优势:

(1)不增加额外的全局变量,

(2)执行过程中所有变量都是在匿名函数内部。

闭包的缺点:

(1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

(2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public

Method),把内部变量当作它的私有属性(private

value),这时一定要小心,不要随便改变父函数内部变量的值。

本文就为大家介绍这里,如果大家对javascript闭包还是不够了解,请阅读相关文章进行补充学习,谢谢大家的阅读。

本文题目:javascript的包,js文件包
链接分享:https://www.cdcxhl.com/article16/dsephdg.html

成都网站建设公司_创新互联,为您提供网站排名网站改版微信公众号自适应网站动态网站外贸网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网站建设