首页 > 其他分享 >word文档转html富文本,富文本编辑器 转成html5代码

word文档转html富文本,富文本编辑器 转成html5代码

时间:2023-12-22 10:01:58浏览次数:48  
标签:function 文本编辑 word html file var return

用我现在最常使用的php框架fastadmin举例子,当然thinkphp或者原生php也是同样的原理,大家理解思路就好了、

 

环境:fastadmin,summernote编辑器 【summernote的居中功能在段落里,且不会吃掉section标签,加上导入word功能之后,简直完美~】   按照国际惯例先放效果图     github上的demo里我还没有换图标,不过fastadmin里的是换了的,效果如下:      

1、thinkphp使用composer安装phpword插件(这个插件能够把word转为html)

composer require phpoffice/phpword

安装完成之后的文件在vender目录下

 

2、打开require统一管理后台插件的js

引入我们需要的ajaxfileupload.js插件(这个插件允许文件通过ajax上传到服务器,而不是form表单)

'ajaxfileupload':'../libs/ajaxfileupload/ajaxfileupload',

 

3、以新增新闻的编辑器为例,打开

 在开头载入需要的组件

define(['jquery', 'bootstrap', 'backend', 'table', 'form','summernote','layer','ajaxfileupload'], function ($, undefined, Backend, Table, Form,summernote,layer,ajaxfileupload) {

 

然后修改add方法

复制代码
add: function () {
    Controller.api.bindevent();

    
    var imageButton = function (context) {
        var ui = $.summernote.ui;
        var button = ui.button({
            contents: '<i class="fa fa-file-image-o"/>',
            tooltip: __('Choose'),
            click: function () {
                parent.Fast.api.open("general/attachmentlect?element_id=&multiple=true&mimetype=image/*", __('Choose'), {
                    callback: function (data) {
                        var urlArr = data.url.split(/\,/);
                        $.each(urlArr, function () {
                            var url = Fast.api.cdnurl(this);
                            context.invoke('editor.insertImage', url);
                        });
                    }
                });
                return false;
            }
        });
        return button.render();
    };
    var attachmentButton = function (context) {
        var ui = $.summernote.ui;
        var button = ui.button({
            contents: '<i class="fa fa-file"/>',
            tooltip: __('Choose'),
            click: function () {
                parent.Fast.api.open("general/attachmentlect?element_id=&multiple=true&mimetype=*", __('Choose'), {
                    callback: function (data) {
                        var urlArr = data.url.split(/\,/);
                        $.each(urlArr, function () {
                            var url = Fast.api.cdnurl(this);
                            var node = $("<a href='" + url + "'>" + url + "</a>");
                            context.invoke('insertNode', node[0]);
                        });
                    }
                });
                return false;
            }
        });
        return button.render();
    };

    // 新增编辑器导入word功能
    var wordBtn = function (context) {
        var ui = $.summernote.ui;
        var button = ui.button({
            contents: '<i class="fa fa-file-word-o"/>',
            tooltip: '导入word',
            click: function () {
                // 点击之后的操作
                layer.open({
                    type: 1,
                    skin: 'layui-layer-rim', //加上边框
                    area: ['420px', '160px'], //宽高
                    content: '<input type="file" id="file" name="file" title="上传word" value="" ><br/><input type="button" value="上传" id="submit" />'
                });
            }
        });
        return button.render();   // return button as jquery object
    };
    $(".summernote,.editor", $('form')).summernote({
        height: 250,
        lang: 'zh-CN',
        fontNames: [
            'Arial', 'Arial Black', 'Serif', 'Sans', 'Courier',
            'Courier New', 'Comic Sans MS', 'Helvetica', 'Impact', 'Lucida Grande',
            "Open Sans", "Hiragino Sans GB", "Microsoft YaHei",
            '微软雅黑', '宋体', '黑体', '仿宋', '楷体', '幼圆',
        ],
        fontNamesIgnoreCheck: [
            "Open Sans", "Microsoft YaHei",
            '微软雅黑', '宋体', '黑体', '仿宋', '楷体', '幼圆'
        ],
        toolbar: [
            ['style', ['style', 'undo', 'redo']],
            ['font', ['bold', 'underline', 'strikethrough', 'clear']],
            ['fontname', ['color', 'fontname', 'fontsize']],
            ['para', ['ul', 'ol', 'paragraph', 'height']],
            ['table', ['table', 'hr']],
            ['insert', ['link', 'picture', 'video']],
            ['select', ['image', 'attachment']],
            ['view', ['fullscreen', 'codeview', 'help','word']],
        ],
        buttons: {
            image: imageButton,
            attachment: attachmentButton,
            word:wordBtn
        },
        dialogsInBody: true,
        followingToolbar: false,
        callbacks: {
            onChange: function (contents) {
                $(this).val(contents);
                $(this).trigger('change');
            },
            onInit: function () {
            },
            onImageUpload: function (files) {
                var that = this;
                //依次上传图片
                for (var i = 0; i < files.length; i++) {
                    Upload.api.send(files[i], function (data) {
                        var url = Fast.api.cdnurl(data.url);
                        $(that).summernote("insertImage", url, 'filename');
                    });
                }
            }
        }
    });


    // 点击上传按钮,发送ajax,上传word文档,并获取到返回的html地址
    // 动态生成的元素需要使用在document上加点击事件
    $(document).on('click','#submit',function(){
        var path = $('#file').val();
        if ($.trim(path) == "") {
            alert("请选择要上传的文件");
            return;
        }


        $.ajaxFileUpload({
            url: 'form',  //这里是服务器处理的代码
            type: 'post',
            secureuri: false, //一般设置为false
            fileElementId: 'file', // 上传文件的id、name属性名
            dataType: 'json', //返回值类型,一般设置为json、application/json
            success: function (data, status) {
                console.log('success')
            },
            error:function(data, status, e){
                console.log('error')
                var responseText = data.responseText;
                // console.log(responseText);
                // 把html赋值给富文本,,并关闭layui
                $('.layui-layer-close').click();
                $(".summernote,.editor", $('form')).summernote('code',responseText);
            }
        });
    });
},
 
复制代码

 

 

4、修改控制器

复制代码
use PhpOffice\PhpWord\PhpWord;

...

public function form(){

    // 接收表单上传的文件,并存储到服务器中
    $file = $_FILES['file']['tmp_name'];//上传的文件
    move_uploaded_file($file,"/words/res.docx");


    // 使用phpword将word转为html
    $phpWord = IOFactory::load('/words/res.docx');
    $xmlWriter = IOFactory::createWriter($phpWord, "HTML");
    $resPath = '/words/res.html';
    $xmlWriter->save($resPath);


    $html = file_get_contents($resPath);
    return $html;
}
复制代码   5、记得public目录下创建一个words文件夹,用来存储word和html文件   ----------------------------------------------------------------------------------------   实践过程中发现base64格式的代码太长、太占空间,于是决定将base64格式的图片转为普通格式的图片,存入服务器   1、修改phpoffice\phpword\src\PhpWord\Element\Image.php 在这个类文件的最后新增一个方法,用于将base64格式的图片转为普通格式图片存入服务器 复制代码
public function base64_image_content($base64_image_content,$path){
        //匹配出图片的格式
        if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){
            $type = $result[2];
            $new_file = $path."/".date('Ymd',time())."/";
            if(!file_exists($new_file)){
                //检查是否有该文件夹,如果没有就创建,并给予最高权限
                mkdir($new_file, 0700);
            }
            $new_file = $new_file.time().rand(100000000000, 900000000000).".{$type}"; // 如果同时上传多张图片,则时间戳相同会存在覆盖,因为加上随机上确保图片名称不重复
       if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){ return '/'.$new_file; }else{ return false; } }else{ return false; } }
复制代码   2、提前创建好存放图片的文件夹 D:/phpstudy_pro/WWW/word/public/word_images   3、修改phpoffice\phpword\src\PhpWord\Writer\HTML\Element\Image.php 原先是将图片以base64格式返回的,改为html里访问服务器图片的格式并返回 复制代码
public function write()
    {
        if (!$this->element instanceof ImageElement) {
            return '';
        }
        $content = '';
        $imageData = $this->element->getImageStringData(true);
        if ($imageData !== null) {
            $styleWriter = new ImageStyleWriter($this->element->getStyle());
            $style = $styleWriter->write();
            $imageData = 'data:' . $this->element->getImageType() . ';base64,' . $imageData;


            // 1、获取到项目根目录
            // ---- D:/phpstudy_pro/WWW/word/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/
            $path = str_replace('\\','/',realpath(dirname(__FILE__).'/'))."/";
            // --- D:/phpstudy_pro/WWW/word
            $path = explode('/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/',$path)[0];
            

            // 2、调用在类中新增的方法,将图片存入 D:/phpstudy_pro/WWW/word/public/word_images
            $imageData = $this->element->base64_image_content($imageData, $path.'/public/word_images');

            
            // 3、替换为html里要显示的格式,替换时根据项目的默认路径灵活修改
            $imgPath = str_replace($path."/","",$imageData); // 原生php版本
            // $imgPath = str_replace($path."/public/","",$imageData); // thinkphp版本
            $content .= $this->writeOpening();


            // 4、返回
            $content .= "<img border=\"0\" style=\"{$style}\" src=\"{$imgPath}\"/>";
            $content .= $this->writeClosing();

        }
        return $content;
    }
复制代码   4、原生php的demo(框架的demo实在太大了,就不放出来了,大家同理自己改写下就好) github地址:https://github.com/chenyingying1016/import_word_to_html.git 下载项目部署到服务器上,访问form.html即可查看效果~

标签:function,文本编辑,word,html,file,var,return
From: https://www.cnblogs.com/com3/p/17920630.html

相关文章

  • 关于kkfileview文件流形式、本地测试html
    <html><inputtype="text"id="url"> <inputtype="button"value="转换"><scripttype="text/javascript"src="https://cdn.jsdelivr.net/npm/js-base64@3.6.0/base64.m......
  • html主体和header中charset
    #如果body中没有charset,则在header中提取$meta=get_meta_charset($html);$charset=preg_match("/charset=[^\w]?([-\w]+)/i",$meta,$temp)?strtolower($temp[1]):"";if(empty($charset)){$header=print_r($html_array['header']......
  • PHP读取word文档
    1.安装1.1composer安装phpoffice/phpwordcomposerrequirephpoffice/phpword1.2后台代码 $file=$this->request->request('file');if(!$file){$this->error(__('Parameter%scannotbeempty','file......
  • 在laravel中使用wkhtmltopdf
    在平时的项目中,可能会遇到把报表生成pdf或jpg图片的需求,使用wkhtmltopdf能方便的生成pdf和jpg图片。1、安装:ubunut:sudoaptinstallwkhtmltopdf(或者下载安装指定版本:https://wkhtmltopdf.org/downloads.html),记住安装的目录,命令名称:wkhtmltoimage和wkhtmltopdf2、laravel......
  • 7、手签名放在文档里面—word
    1、在纸上写名字,然后拍照2、把图片插入word里面,右键【环绕文字】—>【浮于文字上方】3、用裁剪工具,把图片裁小点4、【设置图片格式】的参数就可以了 缺点:因为还是图片,所有它会覆盖文字的这个是没设置前的图片 ......
  • 1、组织架构图—word
    1、在word里面录入所有的文字2、选中一级的文字,按【Tab】键,降级3、选中二级文字,按【Tab】键,降级4、选中三级文字,按【Tab】键,降级    5、将【布局】—>【纸张方向】—>【横向】,然后【Ctrl+A】全选文字,最后【Ctrl+x】剪切文字,点击【插入】—>【smartart】—>【层次结构......
  • React项目中报错:Parsing error: The keyword 'import' is reservedeslint
    记得更改完配置后,要重启编辑器(如:VSCode)!!!记得更改完配置后,要重启编辑器(如:VSCode)!!!记得更改完配置后,要重启编辑器(如:VSCode)!!!这个错误通常发生在你尝试在一个不支持ES6模块语法的环境中使用import关键字。ESLint默认使用的是ES5语法,如果你想使用ES6或者更新的语法,你......
  • uniapp app安卓、ios文件选择 (上传pdf word video img )等
    1、hybrid 必须放在项目根目录下,不然会调用失效:如图 2、建立nvue 子窗体  代码:1<template>2<viewclass="nvue">3<textclass="popup-item"@click="clickfun">选择文件</text>4<textclass="ddddd......
  • HTML5 dialog标签简单使用
     HTML5dialog标签简单使用<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"/><metaname="viewport"content="width=device-width,initial-scale=1.0"/><title>......
  • HTML5新增标签及API
    之前有一天看到了这样的一段代码,居然可以使用dom的id直接调用方法和获取属性,真是刷新了我的认知了。<div><pid="content">aa</p><buttononclick="console.log(content.innerText)">打印内容</button></div> 点击按钮,控制台就可以打印出aa字符串习惯写后端的我前......