粗糙的玩一玩javascript的"编译"(1)

我们的浏览器能加载之前我们写的js?

新建个html,来试验一下:

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta charset="utf-8">
</head>
<body>
<script src="index.js"></script>
</body>
</html>

这里写图片描述
控制台报了:ReferenceError: require is not defined
很遗憾,在网页中还不支持require 这个语法(不代表未来不支持)。

开动大脑
既然node能运行index.js,那么我们是否可以通过nodeJS把require出来的东西给生成一个网页可以识别的代码呢?

var getlib = require("myLib");

// 引入node的一个内置模块
var file = require("fs");
file.writeFile("build.js","");

// 生成网页代码
function genCode(key,value){
    return "var "+key+" = "+value+";\n";
}

for(var k in getlib){
    file.appendFile("build.js",genCode(k,getlib[k]));
}

上面我们就把myLib模块理的js”编译”成了我们网页认识的js了。
我们在html理,引入build.js试试:

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta charset="utf-8">
</head>
<body>
<script src="build.js"></script>
</body>
</html>

这次没有报require is not defined, 说明编译成功。
我们来看看build.js,确实都是我们都网页能认识的js代码:

var age = 22;
var showName = function (){
    console.log('showName');
};

而”编译”之前,我们myLib模块是这样的:

exports.age = 22;
exports.showName = function(){
    console.log('showName');
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值