社区首页 >问答首页 >设置简单测试项目的问题-精益和Browserify

设置简单测试项目的问题-精益和Browserify
EN

Stack Overflow用户
提问于 2017-06-20 06:52:13
回答 1查看 1.2K关注 0票数 2

我试图设置一个简单的测试项目,通过浏览器应用程序来测试ExcelJS,而在我的一生中,我无法让Browserify正常工作。

我使用适当的需求调用将代码绑定到包文件中,当加载页面时,产生的包将引发以下错误:

Uncaught TypeError: Cannot read property 'prototype' of undefined

这个错误似乎是在fs.ReadStream方法上抛出的?

这是我的代码:

index.html

代码语言:javascript
代码运行次数:0
复制
<!DOCTYPE html>
<head>
  <title>Test Excel JS</title>
  <meta charset="utf-8">
  <meta name="description" content="">

  <link rel="stylesheet" href="app.css">
</head>
<body>
  <div>
    <label>Test</label>
    <button onclick="test()">Test this Stuff and Check your console log</button>
  </div>

  <script src="bundle.js"></script>
  <script>
      var test = function(){
          var workbook = generateTestFile();
          console.log(workbook);
      };
  </script>
</body>
</html>

app.js (bundle.js基)

代码语言:javascript
代码运行次数:0
复制
'use strict';

var Excel = require('exceljs');

var isBold = function(dataRow){
    return dataRow.name === "Jeff";
};

var getRowColor = function(dataRow){
    return dataRow.color;
};

var getCellColor = function(dataRow, cell){
    return (dataRow.name === 'John' && cell.value === 0)? 'orange' : dataRow.color;
};

var getFont = function(isBold, color){
    return {
        name: 'Arial Black',
        color: color,
        family: 2,
        size: 14,
        bold: isBold
    };
};

var getTestHeader = function(){
    return [
        {key: "id", header: "Id"},
        {key: "name", header: "Name", width: 32},
        {key: "color", header: "Color", width: 10}
    ];
};

var getTestData = function(){
    return [
        {
            id: 0,
            name: "John",
            color: "green"
        },
        {
            id: 1,
            name: "Rehan",
            color: "blue"
        },
        {
            id: 2,
            name: "Jeff",
            color: "yellow"
        }
    ];
};

var generateTestFile = function(){
    var workbook = new Excel.Workbook();
    var worksheet = workbook.addWorksheet('Sheet 1');

    //Set Column Headers
    worksheet.columns = getTestHeader();

    //Add Rows
    var testData = getTestData();
    var length = testData.length;
    for(var i = 0; i < length; i++){
        worksheet.addRow(testData[i]);
    }

    //Format Rows
    worksheet.eachRow(function(row, rowNumber){
        console.log(row);
        var isBold = isBold(row);
        var rowColor = getRowcolor(row);
        row.eachCell(function(cell, colNumber){
            var cellColor = getCellColor(row, cell);
            console.log(cell);
        });
    });

    return workbook;
};

我怎么才能让这个起作用?我真正想做的就是测试excelJS。我不在乎解决方案是什么,只要我能验证这个库是否工作,我会很高兴的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-20 08:13:42

你应该把exceljs/dist/es5/exceljs.browser变成浏览器而不是exceljs

代码语言:javascript
代码运行次数:0
复制
var Excel = require('exceljs/dist/es5/exceljs.browser');

由于要对app.js进行浏览器化,所以应该在全局范围(窗口)中使函数(变量)可见。

代码语言:javascript
代码运行次数:0
复制
global.generateTestFile = function generateTestFile(){
    // ...
};

不能同时声明具有名称isBold和调用函数表达式isBold的变量,因为var关键字将声明当前作用域中的变量isBold,而您的函数将不可用(参见变量)。因此,请注释掉它,因为它不在代码中使用:

代码语言:javascript
代码运行次数:0
复制
//var isBold = isBold(row);

另外,getRowcolor中也有一个错误。修复它:

代码语言:javascript
代码运行次数:0
复制
var rowColor = getRowСolor(row);

这是给您的gulpfile.js:

代码语言:javascript
代码运行次数:0
复制
var gulp = require('gulp');
var source = require('vinyl-source-stream');
var browserify = require('browserify');
//var uglify = require('gulp-uglify');
//var buffer = require('vinyl-buffer');

gulp.task('default', function() {
  return browserify('app.js')
    .bundle()
    .pipe(source('bundle.js'))
    //.pipe(buffer())
    //.pipe(uglify())
    .pipe(gulp.dest('.'));
});

您也可以浏览exceljs/dist/es5/exceljs.browser.js本身,并在您的应用程序中使用它。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44656422

复制
相关文章
html中嵌入iframe进行父子页面参数传递[通俗易懂]
1.父页面调用子页面函数,选择iframe的id + contentWindow +子页面的函数名([参数列表])
全栈程序员站长
2022/09/14
3.4K0
将外部窗体程序嵌入到QWidget中
下列代码例子中实现的将窗体名字为Example的窗体嵌入到QWidget中。 #include <QApplication> #include <QWindow> #include <QWidget> #include <windows.h> int main(int argc, char *argv[]) { QApplication a(argc, argv); WId winId = (WId)FindWindow(NULL, L"Example"); QWindow *
Qt君
2023/03/17
1.4K0
将外部窗体程序嵌入到QWidget中
将群晖相册嵌入到Hexo博客中
如何高效便捷的在博客中更新自己的动态是困扰很多人的问题,简单的方案就是另起炉灶在博客重新发布一份,但这种方法耗时耗力,因此不建议这样做。从原po平台同步到博客的某个位置应该是最理想的解决方案。对于照片来说,群晖的相册给我提供了一个来源库,那么如果我想让访客浏览我的近照,那么如何把照片从群晖相册同步到博客中就成了实现这一想法的核心问题。
ZONGLYN
2020/06/29
2K0
将群晖相册嵌入到Hexo博客中
Ajax出错并返回整个页面html的问题
有这样一个例子在thinkPHP视图页面执行一个给评论点赞的功能,为了强化用户体验,一般都采用ajax异步请求后台处理点赞数据,成功后页面执行局部更新后的数据即可。前台通常会用到jquery,通过执行jquery的ajax方法更加简单方便的完成任务请求。
世纪访客
2018/08/02
2K0
Ajax出错并返回整个页面html的问题
如何将Tableau Server中的视图嵌入web页面
Tableau作为可视化数据分析软件中的佼佼者,将数据运算与美观的图表完美地嫁接在一起。它的程序很容易上手,各公司可以用它将大量数据拖放到数字“画布”上,转眼间就能创建好各种图表。创建与共享绝妙的数据可视化内容,Tableau 为您呈上唾手可得的可视化分析能力。它帮助您生动地分析实际存在的任何结构化数据,以在几分钟内生成美观的图表、坐标图、仪表盘与报告。利用 Tableau 简便的拖放式界面,您可以自定义视图、布局、形状、颜色等等,帮助您展现自己的数据视角。另外他还适用于多种数据文件与数据库,数据可扩展性强,不限制您所处理的数据大小。
阿Q说代码
2021/05/13
3.2K0
如何将Tableau Server中的视图嵌入web页面
如何将高德地图JS API嵌入到HTML网页内
先去https://lbs.amap.com/注册一下,直接用淘宝/QQ等OpenID既可实现注册。 没有要求实名制,填写姓名的时候,填写英文名。
繁华是客
2023/03/03
4.9K0
输入URL到渲染出整个页面的过程
DNS解析URL > 浏览器发送请求与服务器交互 > 浏览器对接收到的html页面渲染
小黑同学
2021/02/04
9420
输入URL到渲染出整个页面的过程
如何将html格式动态图表网页嵌入ppt中
前几天魔方学院(其实就是我的公众号交流群啦~_~)的一位群友突然在群里提了一个问题! 看了之前推送的REmap相关内容,结果导出的图表是html格式的动态图,不知道如何将此种格式的图表放在ppt中使用。 这确实很尴尬他呀,你不能直接拿着Rstudio跟客户演示呀(而且还不保证每一台PC上都安装有R语言软件),如果是ppt展示,突然退出来,然后用浏览器打开html文件也是够突兀的。 当然这个情况在r语言中其实很普遍,很多依赖底层js语言编写的二次开发包(比如R语言中的recharts、RERmap、Rchar
数据小磨坊
2018/04/11
33.8K2
如何将html格式动态图表网页嵌入ppt中
C#将引用的dll嵌入到exe文件中
4.实现如下代码, 在窗口构造中实现也可以(在窗体事件中无效,如winform_load)
zls365
2020/08/19
4K0
Vscode新建html页面没有模板「建议收藏」
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/171893.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/23
1.2K0
Vscode新建html页面没有模板「建议收藏」
Python odoo中嵌入html简单
在odoo中,通过iframe嵌入 html,页面数据则通过controllers获取,使用jinja2模板传值渲染
py3study
2020/01/15
2.2K0
Python odoo中嵌入html简单
在 HTML 中嵌入 PHP 代码
PHP 天生对 Web 和 HTML 友好,在 PHP 诞生之初,主要用于在 Web 1.0 中构建个人主页,那个时候,PHP 代表的是 Personal Home Page,随着 Web 互联网的发展,在 Web 2.0 时代,PHP 进一步进化为 PHP:Hypertext Preprocessor,即超文本处理器,而 HTML 则是 HyperText Markup Language 的缩写,也就是超文本标记语言。
学院君
2020/05/28
6.3K0
从输入 URL 到渲染页面整个过程 梳理篇
这意味着当前页面即将要被替换成新的页面,不过在这个流程继续之前,浏览器还给了当前页面一次执行 beforeunload 事件的机会,beforeunload 事件允许页面在退出之前执行一些数据清理操作,还可以询问用户是否要离开当前页面,比如当前页面可能有未提交完成的表单等情况,因此用户可以通过 beforeunload 事件来取消导航,让浏览器不再执行任何后续工作。
玖柒的小窝
2021/11/07
7590
从输入 URL 到渲染页面整个过程 梳理篇
NodeJs 中的 HTML 模板
HTML 模板是一种允许我们创建基本 HTML 结构并使用占位符根据从 JSON 文件或数据库中检索到的数据动态生成内容的技术。
海拥
2023/03/09
6.5K0
我们是如何将 Cordova 应用嵌入到 React Native 中
重写一个应用是一件简单的事,可是演进一个应用则是一件复杂的工作。 过去的一年多里,我在工作上的主要职责是:手机 APP 开发。日常主要是编写基于 Ionic 和 Angular 的混合应用,并想方设法地帮助客户将之与 React Native 相结合。在完成了嵌入 WebView 后,重写插件等一系列工作后,便想记录一下这个过程中遇到的坑。 平滑地演进 如我在开头所说,在有足够人力和物力的情况下,最好的方式就是在重写应用。 一来,应用在其生命周期里,经过了不同的开发人员、不同的业务变更,必然有大量的遗留代码
Phodal
2018/01/29
4.9K0
点击加载更多

相似问题

将整个页面重定向到vue.js中的text/html

10

将swf嵌入到html页面

12

如何将整个html文件嵌入到JS中

115

如何将代码作为HTML嵌入到vue.js中

10

将整个HTML页面存储到jQuery变量中

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文