phpダウンロードxlsファイル

<a class="btn btn-primary radius" style="background:green" data-title="导出数据" data-href="" onclick="downloadMessage()" ><i class="Hui-iconfont">&#xe640;</i> 导出数据</a>
<iframe id="ifile" style="display:none"></iframe>

フロントエンドjsは、バックエンドにファイルのダウンロードを要求します。

function downloadMessage(){
	var dom=document.getElementById('ifile');
	dom.src="{
   
   {url('/excel')}}";
}

バックエンドのダウンロードファイル機能:

/**
     * 创建(导出)Excel数据表格
     * @param  array   $list 要导出的数组格式的数据
     * @param  string  $filename 导出的Excel表格数据表的文件名
     * @param  array   $header Excel表格的表头
     * @param  array   $index $list数组中与Excel表格表头$header中每个项目对应的字段的名字(key值)
     * 比如: $header = array('编号','姓名','性别','年龄');
     *       $index = array('id','username','sex','age');
     *       $list = array(array('id'=>1,'username'=>'YQJ','sex'=>'男','age'=>24));
     * @return [array] [数组]
     */
    protected function createtable($list,$filename,$header=array(),$index = array()){
        header("Content-type:application/vnd.ms-excel");
        header("Content-Disposition:filename=".$filename.".xls");
        $teble_header = implode("\t",$header);
        $strexport = $teble_header."\r";
        foreach ($list as $row){
            foreach($index as $val){
                $strexport.=$row->$val."\t";
            }
            $strexport.="\r";
        }

        $strexport=iconv('UTF-8',"GB2312//IGNORE",$strexport);
        exit($strexport);

    }

バックエンド要求応答機能

function excel(){
        $stu = new Stu();
        $cash = $stu->getAllMessage();
        $filename = '求索人员信息';
        $header = array('id','姓名','学号','学院','专业','班级','部门','电话','qq');
        $index = array('id','name','number','college','department','class','section','tel','qq');
        $this->createtable($cash,$filename,$header,$index);
    }

 

おすすめ

転載: blog.csdn.net/qq_43737121/article/details/109133700