整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

前端程序员实现在线预览pdf、word、xls、ppt等文件,超实用!

、前端实现pdf文件在线预览功能

方式一、pdf文件理论上可以在浏览器直接打开预览但是需要打开新页面。在仅仅是预览pdf文件且UI要求不高的情况下可以直接通过a标签href属性实现预览

<a href="文档地址"></a>

方式二、通过jquery插件jquery.media.js实现 这个插件可以实现pdf预览功能(包括其他各种媒体文件)但是对word等类型的文件无能为力。 实现方式: js代码:

<script type="text/javascript" src="jquery-1.7.1.min.js"></script> 
<script type="text/javascript" src="jquery.media.js"></script>
复制代码

html结构:

 <body>
 <div id="handout_wrap_inner"></div>
 </body>
复制代码

调用方式:

<script type="text/javascript"> 
 $('#handout_wrap_inner').media({
		width: '100%',
		height: '100%',
		autoplay: true,
 src:'http://storage.xuetangx.com/public_assets/xuetangx/PDF/PlayerAPI_v1.0.6.pdf',
 }); 
</script>
复制代码

方式三、直接通过页面内嵌iframe

$("<iframe src='"+ this.previewUrl +"' width='100%' height='362px' frameborder='1'>").appendTo($(".video-handouts-preview"));
复制代码

此外还可以在iframe标签之间提供一个提示类似这样

<iframe :src="previewUrl" width="100%" height="100%">
This browser does not support PDFs. Please download the PDF to view it: <a :href="previewUrl">Download PDF</a>
</iframe>
复制代码

方式四、通过标签嵌入内容

<embed :src="previewUrl" type="application/pdf" width="100%" height="100%">

此标签h5特性中包含四个属性:高、宽、类型、预览文件src! 与< iframe > < / iframe > 不同,这个标签是自闭合的的,也就是说如果浏览器不支持PDF的嵌入,那么这个标签的内容什么都看不到!

方式五、标签和iframe使用差别较小

<object :src="previewUrl" width="100%" height="100%">
This browser does not support PDFs. Please download the PDF to view it: <a :href="previewUrl">Download PDF</a>
</object>
复制代码

除方式二以外其他都是直接通过标签将内容引入页面实现预览

方式六、PDFObject

PDFObject实际上也是通过标签实现的直接上代码

<!DOCTYPE html>
<html>
<head>
 <title>Show PDF</title>
 <meta charset="utf-8" />
 <script type="text/javascript" src='pdfobject.min.js'></script>
 <style type="text/css">
 html,body,#pdf_viewer{
 width: 100%;
 height: 100%;
 margin: 0;
 padding: 0;
 }
 </style>
</head>
<body>
 <div id="pdf_viewer"></div>
</body>
<script type="text/javascript">
 if(PDFObject.supportsPDFs){
 // PDF嵌入到网页
 PDFObject.embed("index.pdf", "#pdf_viewer" );
 } else {
 location.href = "/canvas";
 }
</script>
</html>

还可以通过以下代码进行判断是否支持PDFObject预览

if(PDFObject.supportsPDFs){
 console.log("Yay, this browser supports inline PDFs.");
} else {
 console.log("Boo, inline PDFs are not supported by this browser");
}
复制代码

方式七、PDF.js

PDF.js可以实现在html下直接浏览pdf文档,是一款开源的pdf文档读取解析插件,非常强大,能将PDF文件渲染成Canvas。PDF.js主要包含两个库文件,一个pdf.js和一个pdf.worker.js,一个负责API解析,一个负责核心解析。

2、word、xls、ppt文件在线预览功能

word、ppt、xls文件实现在线预览的方式比较简单可以直接通过调用微软的在线预览功能实现 (预览前提:资源必须是公共可访问的)

<iframe src='https://view.officeapps.live.com/op/view.aspx?src=http://storage.xuetangx.com/public_assets/xuetangx/PDF/1.xls' width='100%' height='100%' frameborder='1'>
			</iframe>
复制代码

src就是要实现预览的文件地址 具体文档看这微软接口文档

补充:google的文档在线预览实现同微软(资源必须是公共可访问的)

<iframe :src="'https://docs.google.com/viewer?url="fileurl"></iframe>
复制代码

3、word文件

XDOC可以实现预览以DataURI表示的DOC文档,此外XDOC还可以实现文本、带参数文本、html文本、json文本、公文等在线预览,具体实现方法请看官方文档

下面这种方式可以实现快速预览word但是对文件使用的编辑器可能会有一些限制

<a href="http://www.xdocin.com/xdoc?_func=to&_format=html&_cache=1&_xdoc=http://www.xdocin.com/demo/demo.docx" target="_blank" rel="nofollow">XDOC</a>
复制代码

4、excel文件

目前excel文件已经有了类似pdf.js那样的解析sheet.js

总结:

1、免费纯前端方式实现在线预览word、excel、ppt最优选择微软在线预览(不可编辑)

2、利用后端将文件转为图片,前端以图片形式预览(可行方案)

3、购买在线预览服务例如百度DOC文档服务、永中、I DOC VIEW等

著名:文章内容是从网上搜集资料所得;在次发表只为自己以及头条程序员兄弟日后使用图个方便。

觉得有用记得收藏转发

写文件在编程里面应该是用的最多也最基础的工作了吧。但是,C/C++中文件读写方法有很多种,各种方法的使用场景区别甚大,到底日常工作中,我们什么时候该用哪种方法呢?还是说随便抓一种用就可以?

这篇文章就给大家分享一下C语言文件的各种方法,下一篇再分享一下C++的读写方法:

在window环境下,文件分别两种,一种为文本文件(用记事本可以打开的文件,如txt、xml、html、js等),一种为二进制文件(如图片、软件、压缩包等)

读写文本文件

首先创建一个File对象,这个利用到系统库中的fopen()函数,该函数返回一个File*类型的对象。

FILE *fopen( const char * filename, const char * mode );

第一个参数为:文件路径;第二个参数为打开模式:这个是固定的,具体是什么意思大家可以自己去查一下,没什么特别的,记住就好了。

1、文本文件读写

接下来我们读写一个文本文件,我新建一个test.txt文件并且读取出内容写进newtest.txt文件中,这里有两组函数fgetc/fputc和fgets/fputs函数,故名意意,fgetc是读取出一个字符,而fgets是读取一段字符串,fputc是读写入一个字符,fputs写进一段字符串。我们分别来看一下:

int main()
{
	FILE * fpr = fopen("test.txt","r"); 
	FILE * fpw = fopen("newtest.txt","w"); 
	if(fpr && fpw)
	{	
		while (!feof(fpr))
		{
			char c = (char)fgetc(fpr);			
			cout<<c;
			fputc(c,fpw);
		}
	}
	fclose(fpr);
	fclose(fpw);
	system("pause");
	return 0 ;
}

注意:

1、feof是判断是否读取到文件尾的函数,此处不用EOF来作为读写结束条件是因为:函数如fgetc或getc返回EOF并不一定表示文件结束,当读取文件出错时也会返回EOF,仅凭返回-1就认为文件结束是错误的;正因为如此,我们需要feof()来判断文件是否结束,当然用feof()来判断文件结束时也需要判断读取操作是否出错,这时可以用ferror()来判断,当其为真时表示有错误发生。在实际的程序中,应该每执行一次文件操作,就用用ferror函数检测是否出错。

2、fgetc()返回的是int,如果要在屏幕上打印出字符的话需要转换为char;

上面是一个字符一个字符的读,下面一段一段的读:

FILE * fpr = fopen("test.txt","r"); 
	FILE * fpw = fopen("newtest.txt","w"); 
	if(fpr && fpw)
	{	
		while (!feof(fpr))
		{
			char* buff = new char[1024];
			char* s = fgets(buff,3,fpr);
			cout<<s;
			fputs(s,fpw);
		}
	}
	fclose(fpr);
	fclose(fpw);

这个方法个人不是很推荐,因为在使用过程中经常会报错,这里我如果将以此读取的字符串长度由3改为2或者1就会报错,这个我也搞不清为什么,如果有知道的朋友可以评论帮我解答一下;

读写二进制文件

C语言读写二进制文件通过库函数fread和fwrite实现:

size_t fread(void *buff, size_t sizeofElement, size_t count, FILE *stream);

size_t fwrite(const void *ptr, size_t sizeofElement, size_t count, FILE *stream);

参数解释:buff:缓存区地址

sizeofElement:每次读/写的数据大小

count:要多去多个个sizeofElement大小的数据

stream:文件指针

现在我们来读一张神仙姐姐的图片test.ipg并且将读取到的内容写进newtest.jpg,然后查看是否能打开。

int main()

{

FILE * fpr = fopen("test.jpg","rb");

FILE * fpw = fopen("newtest.jpg","wb");

char* buff = new char[50];

int len = 50;

while (len==50)

{

len = fread(buff,sizeof(char),50,fpr);

fwrite(buff,sizeof(char),len,fpw);

}

fclose(fpr);

fclose(fpw);

system("pause");

return 0 ;

}

运行结果,打开newtest.jpg,结果完美呈现神仙姐姐。

注意以下几点:

1、文件打开方式,不管是读还是写都需要在后面加b,b就是binary二进制的意思,所以这里打开方式是“日本”和“wb”;

2、写入fwrite中的count一定要注意,你的缓存区存了多大的内容这里就写多大的内容,不然会导致文件损坏,因为我定的是每次读取50个char大小的内容,但是文件大小不可能是50的整数啊,最后一次读取的话他肯定会小于50,并且大小不能超过缓存区的大小;

文件内部位置指针

在打开任何文件的时候,都会有一个文件内部位置指针。为什么要在这里介绍这个呢?我们大部分读取文件的时候都是不用去管他的,因为我们基本很少有读取固定位置开始固定长度的需求,都是从开始一直读取到文件结束。

其实我们上面用到的那么多函数,位置指针在文件被打开的时候位置指针是在零为,每读取一次这个指针就会往后面移动你读取的数据两个距离。

这里有三个函数:

1、int fseek(FILE *stream, long int offset, int where)这个函数的作用是将文件位置指针从指定位置(where:系统有定义三个宏SEEK_SET:文件头、SEEK_CUR当前指针位置、SEEK_END文件尾,当然你也可以自己指定位置,比如100、50这样)移动个offset个位置(正数往后移,负数往前移);

2、void rewind(FILE *stream)这个很简单,将位置指针指向文件开头;

3、long int ftell(FILE *stream)这个也很简答,告诉你当前位置指针的位置(相对于文件头);

这可以干嘛呢?最实用的,当然是快速的获取文件长度啊:

我们只需要用fseek将指针移动到文件尾,再用ftell求出当前指针位置就是了:

fseek(fpr,OL,SEEK_END);注意这里的offset一定要给0

ftell(fpr);

TML 实例

<!DOCTYPEhtml><html><head><metacharset="utf-8"><title>菜鸟教程(runoob.com)</title></head><body><h1>我的第一个标题</h1><p>我的第一个段落。</p></body></html>

实例解析

  • DOCTYPE 声明了文档类型

  • 位于标签 <html> 与 </html> 描述了文档类型

  • 位于标签 <body> 与 </body> 为可视化网页内容

  • 位于标签 <h1> 与 </h1> 作为一个标题使用

  • 位于标签 <p> 与 </p> 作为一个段落显示

<!DOCTYPE html> 在HTML5中也是描述了文档类型。

什么是HTML?

HTML 是用来描述网页的一种语言。

  • HTML 指的是超文本标记语言: HyperText Markup Language

  • HTML 不是一种编程语言,而是一种标记语言

  • 标记语言是一套标记标签 (markup tag)

  • HTML 使用标记标签来描述网页

  • HTML 文档包含了HTML 标签文本内容

  • HTML文档也叫做 web 页面

HTML 标签

HTML 标记标签通常被称为 HTML 标签 (HTML tag)。

  • HTML 标签是由尖括号包围的关键词,比如 <html>

  • HTML 标签通常是成对出现的,比如 <b> 和 </b>

  • 标签对中的第一个标签是开始标签,第二个标签是结束标签

  • 开始和结束标签也被称为开放标签和闭合标签

<标签>内容</标签>

HTML 元素

"HTML 标签" 和 "HTML 元素" 通常都是描述同样的意思.

但是严格来讲, 一个 HTML 元素包含了开始标签与结束标签,如下实例:

HTML 元素:

<p>这是一个段落。</p>

Web 浏览器

Web浏览器(如谷歌浏览器,Internet Explorer,Firefox,Safari)是用于读取HTML文件,并将其作为网页显示。

浏览器并不是直接显示的HTML标签,但可以使用标签来决定如何展现HTML页面的内容给用户:

HTML 网页结构

下面是一个可视化的HTML页面结构:

<html>

<head>

<title>页面标题</title>

</head>

<body>

<h1>这是一个标题</h1>

<p>这是一个段落。</p>

<p>这是另外一个段落。</p>

</body>

</html>

只有 <body> 区域 (白色部分) 才会在浏览器中显示。

HTML版本

从初期的网络诞生后,已经出现了许多HTML版本:

版本发布时间
HTML1991
HTML+1993
HTML 2.01995
HTML 3.21997
HTML 4.011999
XHTML 1.02000
HTML52012
XHTML52013

<!DOCTYPE> 声明

<!DOCTYPE>声明有助于浏览器中正确显示网页。

网络上有很多不同的文件,如果能够正确声明HTML的版本,浏览器就能正确显示网页内容。

doctype 声明是不区分大小写的,以下方式均可:

<!DOCTYPE html>

<!DOCTYPE HTML>

<!doctype html>

<!Doctype Html>

通用声明

HTML5

<!DOCTYPE html>

HTML 4.01

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"

"http://www.w3.org/TR/html4/loose.dtd">

XHTML 1.0

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

查看完整网页声明类型 DOCTYPE 参考手册。

中文编码

目前在大部分浏览器中,直接输出中文会出现中文乱码的情况,这时候我们就需要在头部将字符声明为 UTF-8。

HTML 实例

<!DOCTYPEhtml><html><head><metacharset="UTF-8"><title>页面标题</title></head><body><h1>我的第一个标题</h1><p>我的第一个段落。</p></body></html>

如您还有不明白的可以在下面与我留言或是与我探讨QQ群308855039,我们一起飞!