browserfy的brfs插件中出现问题

Issue in brfs plugin of browserify

本文关键字:问题 插件 brfs browserfy      更新时间:2024-05-04

我正试图通过从每个.html文件中读取文件内容,将中的所有.html模板文件转换为一个bundle.js文件。

我在main.js 中写了以下代码

var fs = require('fs');
var templates = {
    'header': fs.readFileSync('app/templates/header.html', 'utf8'),
    'heading': fs.readFileSync('app/templates/heading.html', 'utf8')
}

这是有效的,但当我在cmd:中运行browserify -t brfs main.js > bundle.js时,在bundle.js中添加了一些不必要的包装函数

(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
var templates = {
    'header': "<div class='"headerSection'">'r'n't<div class='"headerSectionWrapper'">'r'n't't<div class='"logo'">{{name}}</div>'r'n't't<div class='"searchBarSection'">'r'n't't't<div class='"searchBar'">'r'n't't't't'r'n't't't</div>'r'n't't't<div class='"searchTextHolder'">'r'n't't't't<form name='"searchform'">'r'n't't't't't<input type='"text'" name='"searchbox'"></input>'r'n't't't't</form>'r'n't't't</div>'r'n't't</div>'r'n't</div>'r'n</div>",
    'heading': "<!-- HTML Template -->'n<h3>heading</h3>'n"
}
},{}]},{},[1]);

如何删除此包装函数?

只需直接运行brfs

$ brfs main.js
var templates = {
    'header': "<div class='"headerSection'">'r'n't<div class='"headerSectionWrapper'">'r'n't't<div class='"logo'">{{name}}</div>'r'n't't<div class='"searchBarSection'">'r'n't't't<div class='"searchBar'">'r'n't't't't'r'n't't't</div>'r'n't't't<div class='"searchTextHolder'">'r'n't't't't<form name='"searchform'">'r'n't't't't't<input type='"text'" name='"searchbox'"></input>'r'n't't't't</form>'r'n't't't</div>'r'n't't</div>'r'n't</div>'r'n</div>",
    'heading': "<!-- HTML Template -->'n<h3>heading</h3>'n"
}

brfs命令随brfs包一起提供。

这是浏览的前奏代码。正是"运行时"使浏览变得有效。即使有一个很小的例子:

echo 'console.log("foo")' | browserify
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({},{},[]);

它与brfs无关,只是browserfy,它是使browserfy在浏览器和节点中工作的魔法。