如何在reactjs

时间:2016-03-17 16:32:35

标签: javascript reactjs jspdf

我想知道如何在反应项目中包含外部JavaScript库。例如,我想导入jspdf库:https://github.com/MrRio/jsPDF/blob/master/jspdf.js并在我的reactjs应用程序中使用它。

到目前为止,我试图像这样使用require:

let React = require('react');
let { Spacing, Typography } = Styles;
let DoughnutChart = require("react-chartjs").Doughnut;
let Chart = require('react-google-charts').Chart;
let { StylePropable, StyleResizable } = Mixins;
let EditableDiv = require('../EditableDiv.jsx');
//some other library
//the library that matter for me
var pdfConverter = require('../utils/jspdf.source.js');

//then I have my classical react code which works and a function to generate ad pdf
_generatePdf: function(){
    console.log('Genrating pdf');
    var doc = new pdfConverter.jsPDF('p','pt');
    var img = new Image();
}

我有以下错误: TypeError:pdfConverter.jsPDF不是函数

为了使它工作,我做了一些丑陋的东西,我将jspdf-source.js的源代码复制到我的react.jsx文件中,然后只调用jsPDF而不是pdfConverter.jsPDF。它绝对没有正确的方法,但无法成功导入和使用该库。

你能告诉我我做错了什么以及如何纠正这个问题? 谢谢

- 编辑 -

当我使用我丑陋的解决方案(将源复制到我的文件中)时,我只需要执行以下操作:

var doc = new jsPDF('p','pt);

它工作得很好,希望我有一个非常大的文件

在@dannyjolie bellow建议的解决方案之后,我直接从npm包导入了jspdf,但我仍然无法使用该库。我尝试了以下代码导致错误:

var pdfConverter = require('jspdf');
var converter = new pdfConverter();
var doc = converter.jsPDF('p', 'pt');

TypeError:pdfConverter不是构造函数 这意味着我必须导入来自包的jsPDF,而不仅仅是jspdf?

然后我尝试

let pdfConverter = require('jspdf');
var converter = pdfConverter.jsPDF;
var doc = new converter('p', 'pt');

ReferenceError:未定义jsPDF

TypeError:转换器不是构造函数

显然,我没有正确的方式输入正确的东西。 我做错了什么?

3 个答案:

答案 0 :(得分:7)

首先,不要使用源文件。只需npm install jspdf --save与其他任何套餐一样,并使用var pdfConverter = require('jspdf');

导入

其次,你在这一行var doc = new pdfConverter.jsPDF('p','pt');

中缺少一个()

做这样的事情:

var converter = new pdfConverter();
var doc = converter.jsPDF('p', 'pt');

答案 1 :(得分:4)

如果在/public/index.html中包含外部js文件链接,则可以使用带有window前缀的外部库。

以JQuery为例。将以下行放在/public/index.html

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>

在您的项目中使用它,如下所示:

window.$("#btn1").click(function(){
  alert("Text: " + $("#test").text());
});

答案 2 :(得分:1)

我知道这已经过时了,但我认为如果有人发布完整的工作样本会有所帮助。我花了一段时间才弄明白这一点,用另一篇文章作为起点:

How to make PDF from React?

假设您正在使用create-react-app,请使用以下内容覆盖您的App.js ...

import React, { Component } from 'react';
import pdfConverter from 'jspdf';
import logo from './logo.svg';
import './App.css';

class App extends Component {
  constructor(props) {
    super(props);
    this.onClick = this.onClick.bind(this);
    this.toDataUrl = this.toDataUrl.bind(this);
  }

  toDataUrl(url, callback) {
    var xhr = new XMLHttpRequest();
    xhr.onload = function() {
      var reader = new FileReader();
      reader.onloadend = function() {
        callback(reader.result);
      }
      reader.readAsDataURL(xhr.response);
    };
    xhr.open('GET', url);
    xhr.responseType = 'blob';
    xhr.send();
  }

  onClick() {
      var doc = new pdfConverter('p','pt','letter');
      //console.log(doc.getFontList() );
      this.toDataUrl('background.jpg', function(base64Img) {
        var imgData = base64Img;
        console.log(imgData);
        console.log('Adding to doc.');
        doc.addImage(imgData, 'JPEG', 0, 0, 612, 792);
        console.log('Image added.');
        doc.setFont('Times', 'Roman');
        doc.setFontSize(22);
        doc.text(20, 50, 'Park Entry Ticket');
        doc.setFontSize(16);
        doc.text(20, 80, 'Address1: ' );
        doc.text(20, 100, 'Address2: ' );
        doc.text(20, 120, 'Entry Date & time: ');
        doc.text(20, 140, 'Expiry date & time: ' );
        console.log('About to save');
        doc.save("test.pdf");
      });
  }

  render() {
    return (
      <div className="App">
        <div className="App-header">
          <img src={logo} className="App-logo" alt="logo" />
          <h2>Welcome to React</h2>
        </div>
        <p className="App-intro">
          To get started, edit <code>src/App.js</code> and save to reload.
            <input type='button'
        onClick={this.onClick} value="Print"/>
        </p>
      </div>
    );
  }
}

export default App;