1 javascript pdf react-native expo
我正在尝试使用该库运行“Hello World”代码react-native-html-to-pdf
并创建 PDF,但我无法在 Expo 上进行设置。你可以帮帮我吗?我尝试使用命令react-native link
。
包.json
{
"main": "node_modules/expo/AppEntry.js",
"scripts": {
"start": "expo start",
"android": "expo start --android",
"ios": "expo start --ios",
"web": "expo start --web",
"eject": "expo eject"
},
"dependencies": {
"expo": "^35.0.0",
"react": "16.8.3",
"react-dom": "16.8.3",
"react-native": "https://github.com/expo/react-native/archive/sdk-35.0.0.tar.gz",
"react-native-html-to-pdf": "^0.8.0",
"react-native-pdf-lib": "^0.2.1",
"react-native-web": "^0.11.7"
},
"devDependencies": {
"babel-preset-expo": "^7.1.0"
},
"private": true
}
Run Code Online (Sandbox Code Playgroud)
应用程序.js
import React, { Component } from 'react';
import {
Text,
TouchableHighlight,
View,
StyleSheet,
} from 'react-native';
import RNHTMLtoPDF from 'react-native-html-to-pdf';
export default class App extends Component {
async createPDF() {
let options = {
html: '<h1>PDF TEST</h1>',
fileName: 'test',
directory: 'Documents',
};
let file = await RNHTMLtoPDF.convert(options)
// console.log(file.filePath);
alert(file.filePath);
}
render() {
return(
<View style={styles.container}>
<TouchableHighlight onPress={this.createPDF}>
<Text>Create PDF</Text>
</TouchableHighlight>
</View>
)
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
});```
Run Code Online (Sandbox Code Playgroud)
如果您使用的是 expo,则无法链接任何库。这就是世博会的局限性。如果您想拥有这样的功能,最好通过从 expo 弹出来切换到裸反应本机应用程序,因为链接在 expo 中不起作用。这是世博会的一个主要限制。
或者你可以查看 Expo Print 的文档,
他们定义了一个打印函数来将 html 保存为 pdf
Print.printToFileAsync(options)
Prints HTML to PDF file and saves it to app's cache directory.
Arguments
options (object) -- A map of options:
html (string) -- HTML string to print into PDF file.
width (number) -- Width of the single page in pixels. Defaults to 612 which is a width of US Letter paper format with 72 PPI.
height (number) -- Height of the single page in pixels. Defaults to 792 which is a height of US Letter paper format with 72 PPI.
base64 (boolean) -- Whether to include base64 encoded string of the file in the returned object.
Returns
Resolves to an object with following keys:
uri (string) -- A URI to the printed PDF file.
numberOfPages (number) -- Number of pages that were needed to render given content.
base64 (string) -- Base64 encoded string containing the data of the PDF file. Available only if base64 option is truthy. It doesn't include data URI prefix data:application/pdf;base64,.
Run Code Online (Sandbox Code Playgroud)
希望能帮助到你。如有疑问请放心
归档时间: |
|
查看次数: |
7836 次 |
最近记录: |