当前位置: 首页 > news >正文

深圳网站制作hi0755乡镇做电器网站能不能营运

深圳网站制作hi0755,乡镇做电器网站能不能营运,那个网站做图片好看,创建网站是怎么赚钱抽象语法树是什么 在计算机科学中#xff0c;抽象语法树#xff08;abstract syntax tree 或者缩写为 *AST*#xff09;#xff0c;或者语法树#xff08;*syntax tree*#xff09;#xff0c;是源代码的抽象语法结构的树状表现形式#xff0c;这里特指编程语言的源代码… 抽象语法树是什么 在计算机科学中抽象语法树abstract syntax tree 或者缩写为 *AST*或者语法树*syntax tree*是源代码的抽象语法结构的树状表现形式这里特指编程语言的源代码。树上的每个节点都表示源代码中的一种结构。之所以说语法是「抽象」的是因为这里的语法并不会表示出真实语法中出现的每个细节。1 果然比较抽象不如先看几个例子 抽象语法树举例 foo hello world; /*------------- | assign() | ------------- X X X X ------- ----------------- | foo | | hello world | ------- ----------------- */if (foo true) {bar hello world;alert(bar); } /*------ | if | ------ X X X X -------------- ------------- | equal() | | if_body | -------------- ------------- X X X X X X X X ------- -------- ------------- ------------ | foo | | true | | assign() | | alert() | ------- -------- ------------- ------------ X X X X X X ------- ----------------- -------| bar | | hello world | | bar |------- ----------------- ------- */从上述两个例子可以看出抽象语法树是将源代码根据其语法结构省略一些细节比如括号没有生成节点抽象成树形表达。 抽象语法树在计算机科学中有很多应用比如编译器、IDE、压缩优化代码等。下面介绍一下抽象语法树在 JavaScript 中的应用。 JavaScript 抽象语法树 构造 JavaScript 抽象语法树有多种工具比如 v8、SpiderMonkey、UglifyJS 等这里重点介绍 UglifyJS。 UglifyJS UglifyJS 是使用最广的 JavaScript 压缩工具之一而且自身也是用 JavaScript 写的使用它的方法很简单需要 nodejs 环境 首先全局安装 [sudo ]npm install -g uglify-js然后就可以使用了 uglifyjs -m srcFileName.js -o destFileName.min.js关于 UglifyJS 的用法这里就不多介绍了我们要做的是一些更有趣的事情。 UglifyJS Tools UglifyJS 提供了一些工具用于分析 JavaScript 代码包括 parser把 JavaScript 代码解析成抽象语法树code generator通过抽象语法树生成代码mangler混淆 JavaScript 代码scope analyzer分析变量定义的工具tree walker遍历树节点tree transformer改变树节点生成抽象语法树 使用 UglifyJS 生成抽象语法树很简单 首先安装 UglifyJS 为 npm 包 npm install uglify-js --save-dev然后使用 parse 方法即可 var UglifyJS require(uglify-js);var ast UglifyJS.parse(function sum(foo, bar){ return foo bar; });这样生成的 ast 即为那一段代码的抽象语法树。那么我们怎么使用呢 使用 mangler 压缩代码 使用 mangler 可以通过将局部变量都缩短成一个字符来压缩代码。 var UglifyJS require(uglify-js);var ast UglifyJS.parse(function sum(foo, bar){ return foo bar; }); ast.figure_out_scope(); ast.mangle_names(); console.log(ast.print_to_string()); // function sum(a,b){return ab}使用 walker 遍历抽象语法树 使用 walker 可以遍历抽象语法树这种遍历是深度遍历。 var UglifyJS require(uglify-js);var ast UglifyJS.parse(function sum(foo, bar){ return foo bar; }); ast.figure_out_scope(); ast.walk(new UglifyJS.TreeWalker(function(node) {console.log(node.print_to_string()); })); /* function sum(foo,bar){return foobar} function sum(foo,bar){return foobar} sum foo bar return foobar foobar foo bar */UglifyJS 已经提供了直接压缩代码的脚本walker 看上去貌似也没啥用那么这些工具有什么使用场景呢 抽象语法树的应用 利用抽象语法树重构 JavaScript 代码 假如我们有重构 JavaScript 的需求它们就派上用场啦。 下面考虑这样一个需求 我们知道parseInt 用于将字符串变成整数但是它有第二个参数表示以几进制识别字符串若没有传第二个参数则会自行判断比如 parseInt(10.23); // 10 转换成正整数 parseInt(10abc); // 10 忽略其他字符 parseInt(10, 10); // 10 转换成十进制 parseInt(10, 2); // 2 转换成二进制 parseInt(0123); // 83 or 123 不同浏览器不一样低版本浏览器会转换成八进制 parseInt(0x11); // 17 转换成十六进制因为有一些情况是和我们预期不同的所以建议任何时候都加上第二个参数。 下面希望有一个脚本查看所有 parseInt 有没有第二个参数没有的话加上第二个参数 10表示以十进制识别字符串。 使用 UglifyJS 可以实现此功能 #! /usr/bin/env nodevar U2 require(uglify-js);function replace_parseint(code) {var ast U2.parse(code);// accumulate parseInt() nodes in this arrayvar parseint_nodes [];ast.walk(new U2.TreeWalker(function(node){if (node instanceof U2.AST_Call node.expression.print_to_string() parseInt node.args.length 1) {parseint_nodes.push(node);}}));// now go through the nodes backwards and replace codefor (var i parseint_nodes.length; --i 0;) {var node parseint_nodes[i];var start_pos node.start.pos;var end_pos node.end.endpos;node.args.push(new U2.AST_Number({value: 10}));var replacement node.print_to_string({ beautify: true });code splice_string(code, start_pos, end_pos, replacement);}return code; }function splice_string(str, begin, end, replacement) {return str.substr(0, begin) replacement str.substr(end); }// test itfunction test() {if (foo) {parseInt(12342);}parseInt(0012, 3); }console.log(replace_parseint(test.toString()));/* function test() {if (foo) {parseInt(12342, 10);}parseInt(0012, 3); } */在这里使用了 walker 找到 parseInt 调用的地方然后检查是否有第二个参数没有的话记录下来之后根据每个记录用新的包含第二个参数的内容替换掉原内容完成代码的重构。 也许有人会问这种简单的情况用正则匹配也可以方便的替换干嘛要用抽象语法树呢 答案就是抽象语法树是通过分析语法实现的有一些正则无法或者很难做到的优势比如parseInt() 整个是一个字符串或者在注释中此种情况会被正则误判 var foo parseInt(12345); // parseInt(12345);抽象语法树在美团中的应用 在美团前端团队我们使用 YUI 作为前端底层框架之前面临的一个实际问题是模块之间的依赖关系容易出现疏漏。比如 YUI.add(mod1, function(Y) {Y.one(#button1).simulate(click);Y.Array.each(array, fn);Y.mod1 function() {/**/}; }, , {requires: [node,array-extras] }); YUI.add(mod2, function(Y) {Y.mod1();// Y.io(uri, config); }, , {requires: [mod1,io] });以上代码定义了两个模块其中 mod1 模拟点击了一下 id 为 button1 的元素执行了 Y.Array.each然后定义了方法 Y.mod1最后声明了依赖 node 和 array-extrasmod2 执行了 mod1 中定义的方法而 Y.io 被注释了最后声明了依赖 mod1 和 io。 此处 mod1 出现了两个常见错误一个是 simulate 是 Y.Node.prototype 上的方法容易忘掉声明依赖 node-event-simulate3另一个是 Y.Array 上只有部分方法需要依赖 array-extras故此处多声明了依赖 array-extras4mod2 中添加注释后容易忘记删除原来写的依赖 io。 故正确的依赖关系应该如下 YUI.add(mod1, function(Y) {Y.one(#button1).simulate(click);Y.Array.each(array, fn);Y.mod1 function() {/**/}; }, , {requires: [node,node-event-simulate] }); YUI.add(mod2, function(Y) {Y.mod1();// Y.io(uri, config); }, , {requires: [mod1] });为了使模块依赖关系的检测自动化我们创建了模块依赖关系检测工具它利用抽象语法树分析出定义了哪些接口使用了哪些接口然后查找这些接口应该依赖哪些模块进而找到模块依赖关系的错误大致的过程如下 找到代码中模块定义YUI.add的部分分析每个模块内函数定义变量定义赋值语句等找出符合要求以 Y 开头的输出接口如 mod1 中的 Y.mod1生成「接口 - 模块」对应关系分析每个模块内函数调用变量使用等找出符合要求的输入接口如 mod2 中的 Y.oneY.Array.eachY.mod1通过「接口 - 模块」对应关系找到此模块应该依赖哪些其他模块分析 requires 中是否有错误使用此工具保证每次提交代码时依赖关系都是正确无误的它帮助我们实现了模块依赖关系检测的自动化。 总结 抽象语法树在计算机领域中应用广泛以上仅讨论了抽象语法树在 JavaScript 中的一些应用期待更多的用法等着大家去尝试和探索。 Reference Wikipedia ASTUglifyJSnode-event-simulateY.Array.each
http://www.ihoyoo.com/news/32056.html

相关文章:

  • 湛江专业网站建设公司网页设计与制作课程思政
  • 做钓鱼网站犯法吗网上推
  • 绍兴网站制作方案营销策划方案的步骤
  • 商务网站设计论文电子贺卡怎么制作
  • 在线旅游网站哈尔滨工程建设信息网官网
  • 网站建设为什么要推广哪个网站可以做免费宣传
  • 旅行社的网站建设做网站租什么服务器
  • 蒲城县住房和城乡建设局网站东莞seo建站优化哪里好
  • 网站开发需求描述网站建设与网页设计从入门到精通 pdf
  • 微信 网站 优劣势在百度做网站需要什么资料
  • 网站建设实训主要收获及体会巴马网站建设
  • 成都比较好的网站建设公司免费flash网站模板
  • 网站系统开发流程口腔医院东莞网站建设
  • wordpress 不能发送邮件seo优化推广公司
  • 建立网站的公司杭州汽车工厂网站建设
  • 白城学习做网站的学校网站开发经验简历
  • 昆明网站设计方案黄金网站软件app大全下载
  • 最好的自助建站系统图片添加文字在线制作
  • 360建站工具建筑人才网官方
  • 网站开发项目的需求分析电子商务平台开发内容
  • wordpress的导航源码宿迁新站seo
  • 服务器网站建设教程c 做的网站又哪些
  • 开通网站后营业推广策划
  • 网站开发和后台维护俄罗斯乌克兰战争
  • fullpage wow做的网站太原模板建站平台
  • 做网站买完域名还要免费咨询皮肤科专家
  • 注册域名怎么做网站怎么看公司网站做的好不好哦
  • 外贸网站建设知识 列表用vs代码做网站
  • 搜索引擎优化核心文山seo公司
  • 猪八戒做网站要多少钱有哪些做外贸免费的网站