导出

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="utf-8" />

    <!-- disable IE compatible view -->

    <meta http-equiv="X-UA-Compatible" content="IE=edge" />

    <meta name="spreadjs culture" content="zh-cn" />

    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" , user-scalable=no" />

    <title>SpreadJS Demo : 导入导出Excel、导出PDF、打印</title>

    <!-- CDN Reference    -->

    <link rel="icon" type="image/png" href="https://demo.grapecity.com.cn/SpreadJS/TutorialSample/icon.ico" />

    <link rel=" stylesheet" type="text/css" href="https://cdn.grapecity.com.cn/spreadjs/css/basscss.min.css" />

    <link rel="stylesheet" type="text/css" href="https://cdn.grapecity.com.cn/spreadjs/css/gc.spread.sheets.excel2013white.12.0.6.css" />

    <script type="text/javascript" src="https://cdn.grapecity.com.cn/spreadjs/scripts/gc.spread.sheets.all.12.0.6.min.js"></script>

    <script type="text/javascript" src="https://cdn.grapecity.com.cn/spreadjs/scripts/resources/zh/gc.spread.sheets.resources.zh.12.0.6.min.js"></script>

    <script type="text/javascript" src="https://cdn.grapecity.com.cn/spreadjs/scripts/jquery-1.11.1.min.js"></script>

    <script type="text/javascript" src="https://demo.grapecity.com.cn/SpreadJS/TutorialSample/js/spread/license.js"></script>

    <script type="text/javascript" src="gc.spread.excelio.12.0.0.min.js"></script>

    <script type="text/javascript" src="model1.js"></script>

    <script type="text/javascript" src="exceldata.js"></script>

    <script type="text/javascript" src="gc.spread.sheets.charts.12.0.0.min.js"></script>

    <script type="text/javascript" src="File.Saver.js"></script>

    <script type="text/javascript" src="gc.spread.sheets.print.12.0.0.min.js"></script>

    <script type="text/javascript" src="gc.spread.sheets.pdf.12.0.0.min.js"></script>

    <script type="text/javascript" src="fonts.js"></script>

    <!-- <script type="text/javascript" src="js/model.js"></script> -->

    <!-- <script type="text/javascript" src="data/data.ssjson"></script> -->

    <!-- Local Reference

    <link rel="icon" type="image/png" href="images/icon.ico" />

    <link rel="stylesheet" type="text/css" href="css/basscss.min.css ">

    <link rel="stylesheet" type="text/css" href=" css/gc.spread.sheets.excel2013white.12.0.6.css">

    <script type="text/javascript" src="scripts/gc.spread.sheets.all.12.0.6.min.js"></script>

    <script type="text/javascript" src="/scripts/gc.spread.sheets.resources.zh.12.0.6.min.js"></script>

    <script type="text/javascript" src="scripts/jquery-1.11.1.min.js"></script>

    <script type="text/javascript" src="https://demo.grapecity.com.cn/SpreadJS/TutorialSample/js/spread/license.js"></script>

-->

    <!-- 页面内自定义 CSS-->

    <style>

        body {

        background: rgb(250, 250, 250);

        color: #333;

        font-family: mtcorsva !important;

      }

      #ss {

          border: 1px #ccc solid;

      }

      .container {

        width: 95%;

        background: rgb(250, 250, 250);

        margin: 0 auto;

        height: 600px;

      }

      .full-height {

        height: 100%;

      }

        .left{

            height: 100%;

            overflow: auto;

        }

    </style>

</head>

<body>

    <div class="container">

        <div class="clearfix border-bottom">

            <div class="col col-8">

                <h3>SpreadJS Demo : 导入导出Excel、导出PDF、打印</h3>

            </div>

            <div class="col col-4 right-align align-middle">

                <h5>

                    <ul class="list-reset">

                        <li class="inline-block mr1"><a class="btn" href="https://www.grapecity.com.cn/developer/spreadjs "

                                target="_blank ">产品官网</a></li>

                        <li class="inline-block mr1"><a class="" href="https://gcdn.grapecity.com.cn/showforum-185-1.html "

                                target="_blank ">论坛求助</a></li>

                        <li class="inline-block mr1"><a class="" href="https://demo.grapecity.com.cn/SpreadJS/TutorialSample/#/samples "

                                target="_blank ">更多示例</a></li>

                    </ul>

                </h5>

            </div>

        </div>

        <div class="full-height clearfix mt2">

            <div class="col col-3 left">

                <div class="inputContainer">

                    <input style='width: 173px;' type="file" id="fileDemo" class="input">

                    <input type="button" id="loadExcel" value="导入" class="button">

                </div>

                <div class="inputContainer">

                    <input id="exportFileName" value="export.xlsx" class="input">

                    <input type="button" id="saveExcel" value="导出" class="button">

                </div>

                <label>密码:

                    <input type="password" id="password">

                </label>

                <div>

                    <input type="button" id="pdf" value="导出PDF" class="button">

                </div>

                <div>

                    <input type="button" id="print" value="打印" class="button">

                </div>


            </div>

            <div class="col col-9 full-height ">

                <div id="ss" style="height:680px; font-family:simkai"></div>

                <div id="ss1" style="display: none;"></div>

            </div>

        </div>

    </div>

</body>

<script type="text/javascript ">

    var spreadNS = GC.Spread.Sheets;

    $(document).ready(function () {

        var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss"));

        var sheet = spread.getActiveSheet();

        // spread.fromJSON(model1);

        var excelIo = new GC.Spread.Excel.IO();

    /*-----------------导入Excel--------------------------*/

        document.getElementById('loadExcel').onclick = function(){

            var excelFile = document.getElementById('fileDemo').files[0];

            var password = document.getElementById('password').value;

            excelIo.open(excelFile,function(json){

                var obj = json;

                spread.fromJSON(obj);

            },{password: password});

        };

    /*-------------------------导出Excel---------------------------------*/

            document.getElementById('saveExcel').onclick = function() {

            var fileName = document.getElementById('exportFileName').value;

            var password = document.getElementById('password').value;

            if (fileName.substr(-5, 5) !== '.xlsx') {

                fileName += '.xlsx';

            }

            var json = spread.toJSON();

            excelIo.save(json, function (blob) {

                saveAs(blob, fileName);

            }, function (e) {

                console.log(e);

            }, {password: password});

        }

    /*----------------------------- 导出PDF-------------------------------------*/


        var fontsObj = fonts;

        // 注册一个自定义字体

        registerCustomFont(fontsObj);

        setPrintInfo(spread);

        var style = new GC.Spread.Sheets.Style();

        style.font = "8pt simkai";

        for (var i = 0; i < spread.getSheetCount(); i++) {

            spread.sheets[i].setDefaultStyle(style,GC.Spread.Sheets.SheetArea.viewport);

        }

        function registerCustomFont(fontsObj) {

            var fonts = {

                normal: fontsObj["simkai.ttf"]

            };

            GC.Spread.Sheets.PDF.PDFFontsManager.registerFont('simkai', fonts);

        }


        document.getElementById('pdf').onclick = function(){

            spread.savePDF(function(blob){

                saveAs(blob,'download.pdf');

            },

            function (error) {

                console.log(error);

            },

            {

                title:'Test Title', // 导出PDF文件的参数

                author:'Test Author',

                subject:'TestSubject',

                keywords:'Text Keywords',

                creator:'test Creator'

            });

        }

    function setPrintInfo(spread) {

        var sheet = spread.getActiveSheet();

        var printInfo = sheet.printInfo();

        printInfo.showBorder(false);

        printInfo.showGridLine(false);

        printInfo.showColumnHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);

        printInfo.showRowHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);

        sheet.printInfo(printInfo);

}


    /*--------------------------打印-------------------------*/

    document.getElementById('print').onclick = function(sheetsindex) {

          // spread.print(3);

            printSetting(spread);

        }

//打印设置

function  printSetting( ) {

        var sheet = spread.getActiveSheet();

        var printInfo = sheet.printInfo();

        //打印设置

        printInfo.paperSize(new GC.Spread.Sheets.Print.PaperSize(GC.Spread.Sheets.Print.PaperKind.a4));

        printInfo.margin({ top: 0, bottom: 0, left: 0, right: 0, header: 0, footer: 0 });

        //是否打印控件的外边框

        printInfo.showBorder(false);

        //是否打印网格线(默认打印)

        printInfo.showGridLine(false);

        printInfo.zoomFactor(0.8);//缩放

        printInfo.qualityFactor(1);//打印的质量因子

        printInfo.orientation(GC.Spread.Sheets.Print.PrintPageOrientation.portrait);//打印的页面方向。portrait landscape

        printInfo.centering(GC.Spread.Sheets.Print.PrintCentering.horizontal);//打印页面的居中方式。

        printInfo.showColumnHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);//获取或设置是否打印列标题。

        printInfo.showRowHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);

        //设置是否以黑白打印

        printInfo.blackAndWhite(true);

        for (var i = 0; i < spread.getSheetCount(); i++) {

            spread.sheets[i].printInfo(printInfo);

        }

            spread.print(2);

    }

});

</script>

</html>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,383评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,522评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,852评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,621评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,741评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,929评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,076评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,803评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,265评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,582评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,716评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,395评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,039评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,027评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,488评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,612评论 2 350

推荐阅读更多精彩内容