Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

fis-prepackager-m2c

Package Overview
Dependencies
Maintainers
1
Versions
30
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

fis-prepackager-m2c

A modular analysis tool

  • 0.0.13
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
Maintainers
1
Weekly downloads
 
Created
Source

fis-prepackager-m2c

自动为代码添加闭包代码,在代码编写时就无需手动添加,使得编写前端模块化代码的开发体验与Node.js一致。

该插件不同于FIS内置插件fis-postprocessor-jswrapper,只是简单的添加包装,而是将代码转化成可以直接在浏览器执行的代码。

##安装与使用

1.全局安装

npm install fis-prepackager -g

2.开启和配置插件

在fis-conf.js中使用如下代码:

fis.config.merge('modules.prepackager','m2c');
fis.config.merge('settings.prepackager.m2c',{
	options: {
		ns: 'sm',
		exclude: ['**/vue.js']
	},
	tmpl: {
		js: '<script type="text/javascript" src="{0}"></script>',
		css: '<link rel="stylesheet" type="text/css" href="{0}">'
	}
});

settings说明

options:常用的一些设置主要有:

1、ns:命名空间,模块化代码转成闭包后使用的命名空间,默认'alp'。

2、exclude:排除一些已存在的使用require关键字的文件,比如用webpack或browerify打包的文件。

在项目中使用

1.按nodejs的开发方式写js

f.js内容

var t = '马云'
module.exports.obj = {
		a:t
}

a-object.js内容

var f = require('./f.js');
module.exports = {
	sayName: function(name) {
		console.log(name);
		console.log(f.obj.a);
	}
}

在script标签中加data-main作为标识

<!DOCTYPE html>
<html>
<head>
	<title></title>
</head>
<body>
	<script type="text/javascript" data-main>
		var a = require('./a-object.js');
		a.sayName('您好');
	</script>
</body>
</html>

2.执行fis release -d output

文件结果

<!DOCTYPE html>
<html>
<head>
	<title></title>
	</head>
	<body>
	<script type="text/javascript" src="f.js"></script>
	<script type="text/javascript" src="a-object.js"></script>
	<script type = "text/javascript">
	window.sm = window.sm || {};
	(function (sm, a_object_js) {
		 var a = a_object_js;
	     a.sayName('你好');
	 }(sm, sm.a_object_js));
</script>
</body>
</html>

f.js

window.sm = window.sm || {};
(function (sm) {
	var t = '马云'
	sm.obj = { a: t };
 }(sm));

a-object.js

window.sm = window.sm || {};
(function (sm) {
	var f = sm;
	sm.a_object_js = {
		sayName: function (name) {
			console.log(name);
			console.log(f.obj.a);
		}
	};
}(sm));

FAQs

Package last updated on 03 Dec 2015

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc