js數(shù)組讹躯,對(duì)象和json格式的處理-js取表格數(shù)據(jù),json格式異步請(qǐng)求

推薦一個(gè)網(wǎng)站缠劝,建議大家去看看怎樣快速而優(yōu)雅地遍歷 JavaScript 數(shù)組

第一段

場(chǎng)景:php將數(shù)據(jù)取出便利到模版后,自己用js取出模版的數(shù)據(jù)骗灶,組裝成json格式提交到一個(gè)控制器惨恭。比如代碼如下:

<tbody>
     <tr>
        <td>15</td>
        <td>1</td>
        <td>1</td>
        <td>15</td>
     </tr>
     <tr>
        <td>16</td>
        <td>1</td>
        <td>1</td>
        <td>16</td>
     </tr>
     <tr>
        <td>17</td>
        <td>1</td>
        <td>1</td>
        <td>17</td>
     </tr>
     </tbody>
  • 取出數(shù)據(jù)的代碼
// 取出標(biāo)題部分
var thead = new Object();
      $("thead tr th").each(function(i){
         thead[i] = $(this).text();
     });
 console.log(thead);
// tbody
var datas = new Object();
$("tbody tr").each(function(i){
    datas[i] = new Object();
    datas[i]['id'] = $(this).children("td").eq(0).text();
    datas[i]['web_id'] = $(this).children("td").eq(1).text();
    datas[i]['game_id'] = $(this).children("td").eq(2).text();
    datas[i]['username'] = $(this).children("td").eq(3).text();
});
//                console.log(datas);
//                datas = JSON.stringify(datas);
//                console.log(datas);
//// 組裝標(biāo)題和內(nèi)容
var data = new Object();
        data['thead'] = thead;
        data['datas'] = datas;
// ajax處理
$.ajax({
        type: "GET",
        url: "{{ url('excel') }}",
        data: data,
        dataType:'json',
        success: function (data) {
            alert(data.msg);
        }

    })

注意事項(xiàng):
1。數(shù)組和對(duì)象使用介紹:數(shù)組和對(duì)象要預(yù)定義耙旦。而且一次預(yù)定義只能定義一維數(shù)組脱羡。
所以我們?nèi)绻枰褂枚S數(shù)組,就可以在內(nèi)部再定義一個(gè)數(shù)組免都,然后賦值給外層數(shù)組锉罐。
2.數(shù)組或?qū)ο蟮氖褂眠x擇:JSON.stringify(datas);是將對(duì)象轉(zhuǎn)換成json格式。此處其實(shí)使用new Array;也可以取出數(shù)據(jù)绕娘。但是我們還是用對(duì)象比較符合需求
3.打优Ч妗:數(shù)組活著對(duì)象的時(shí)候,我們打印可以使用console.log(datas),但是使用documen.write(datas)是不能打印數(shù)組對(duì)象的险领。我們?nèi)绻蛴【唧w某個(gè)值侨舆,使用這兩種方式都可以


ajax請(qǐng)求處理

  • 在控制器里面打印ajax提交的數(shù)據(jù)
$request = $request->all();
 dd($request);
直接傳遞datas秒紧,控制器的到的數(shù)據(jù)
傳遞`JSON.stringify(datas)`的到的結(jié)果
把表單頭部尾部都組裝請(qǐng)求打印后結(jié)果

我有點(diǎn)困惑,為什么我傳對(duì)象過(guò)去挨下,的到的卻是數(shù)組呢熔恢?還有,其實(shí)用不用dataType:'json',的到的結(jié)果都是一樣的臭笆。但是此處使用了它叙淌,為什么傳遞的時(shí)候卻是傳遞JSON.stringify(datas)的到的結(jié)果圖的結(jié)果呢


  • 如果我們想獲取tr或者td的條數(shù),可以這樣
var num = $("#example1 tbody tr").toArray();  //獲取總記錄條數(shù)
//    alert(num.length);

第二段

我發(fā)現(xiàn)我不能使用ajax請(qǐng)求去打印數(shù)據(jù)愁铺,因?yàn)榭刂破骼锩娴?code>excel是直接導(dǎo)出的一個(gè)結(jié)果鹰霍,就相當(dāng)于是返回給我我們數(shù)據(jù)。而ajax又不能接受處理文件這個(gè)數(shù)據(jù)帜讲。所以我此處用了post提交的方式

  • 先來(lái)看一個(gè)一維的數(shù)組提交
var jsPost = function(action, values) {
  var id = Math.random();
  document.write('<form id="post' + id + '" name="post'+ id +'" action="' + action + '" method="post">');
  for (var key in values) {
    document.write('<input type="hidden" name="' + key + '" value="' + values[key] + '" />');
  }
  document.write('</form>');  
  document.getElementById('post' + id).submit();
}
jsPost('b.html', {
  'username': 'zhangsan',
  'password': '123'
});

我又將第一次的代碼做了修改
1.二維對(duì)象取值的時(shí)候衅谷,$(this).children("td").eq(1).text();這種方法不靈活,因?yàn)樗菍?xiě)死的似将。應(yīng)該再用each遍歷一次取值
2.對(duì)象遍歷使用for(var key in value),
3.post傳遞的時(shí)候获黔,要把行的個(gè)數(shù)傳遞過(guò)去,因?yàn)槲覀償?shù)組的形式傳遞的是一維數(shù)組在验,傳遞后還要拆分成二維數(shù)組打印

<script>
            $(function(){
            function excel(){
                var datas = new Object();
                $("#example1 tbody tr").each(function(i){
                    datas[i+1] = new Object();
                    $(this).children("td").each(function(j){
                       datas[i+1][j] = $(this).text();
                    });
                });

                datas[0] = new Object();
                $("#example1 thead tr th").each(function(i){
                    datas[0][i] = $(this).text();
                });

//                取出每一行的條數(shù)
                var num = $("#example1 thead tr th").toArray().length;

                var jsPost = function(action, v, num) {
                    var id = Math.random();
                    document.write('<form id="post' + id + '" name="post'+ id +'" action="' + action + '" method="post">');
                    document.write('<input type="hidden" name="_token" value="{{ csrf_token() }}">');
                    document.write('<input type="hidden" name="num" value="'+num+'">');
// 此處遍歷可以根據(jù)文章頭部推薦的文章做修改玷氏,但我這里是用的自己的方式
                    for (var k in v) {
                        for(var key in v[k]){
                            document.write('<input type="hidden" name="' + k+'_'+key + '" value="' + v[k][key] + '" />');
                        }
                    }
                    document.write('</form>');
                    document.getElementById('post' + id).submit();
                };
               jsPost("{{ url('/excel') }}", datas, num);
            }
        </script>
  • 控制器代碼
$num = $request->input('num');   //接收的是一維數(shù)組,需要拆分
        $request = $request->except(['_token','num']);
        //把一維數(shù)組拆分成二維
        $datas = array_chunk($request,$num);
          \Excel::create('Filename', function($excel)use($datas) {

            $excel->sheet('Sheetname', function($sheet)  use($datas) {

                $sheet->fromArray($datas);

            });

        })->export('xls');
  • 代碼

function excel(){
    var datas = new Object();
    $("#example1 tbody tr").each(function(i){
        datas[i+1] = new Object();
        $(this).children("td").each(function(j){
            datas[i+1][j] = $(this).text();
        });
    });
    datas[0] = new Object();
    $("#example1 thead tr th").each(function(i){
        datas[0][i] = $(this).text();
    });

//                取出每一行的條數(shù)
    var num = $("#example1 thead tr th").toArray().length;
    // var token = $("input[name='_token']").val();
    // console.log(token);
    //取出打印頭
    var head = $(".content-header h1").text();

    var jsPost = function(action, v, num) {
        var id = Math.random();
        document.write('<form id="post' + id + '" name="post'+ id +'" action="' + action + '" method="post">');
        // document.write('<input type="hidden" name="num" value="'+token+'">');
        document.write('<input type="hidden" name="num" value="'+num+'">');
        document.write('<input type="hidden" name="head" value="'+head+'">');
        for (var k in v) {
            for(var key in v[k]){
                document.write('<input type="hidden" name="' + k+'_'+key + '" value="' + v[k][key] + '" />');
            }
        }
        document.write('</form>');
        document.getElementById('post' + id).submit();
    };
    jsPost('/excel', datas, num);
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末腋舌,一起剝皮案震驚了整個(gè)濱河市盏触,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌块饺,老刑警劉巖赞辩,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異授艰,居然都是意外死亡辨嗽,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)淮腾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)糟需,“玉大人,你說(shuō)我怎么就攤上這事谷朝≈扪海” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵圆凰,是天一觀的道長(zhǎng)杈帐。 經(jīng)常有香客問(wèn)我,道長(zhǎng)专钉,這世上最難降的妖魔是什么娘荡? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任干旁,我火速辦了婚禮,結(jié)果婚禮上炮沐,老公的妹妹穿的比我還像新娘争群。我一直安慰自己,他們只是感情好大年,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布换薄。 她就那樣靜靜地躺著,像睡著了一般翔试。 火紅的嫁衣襯著肌膚如雪轻要。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天垦缅,我揣著相機(jī)與錄音冲泥,去河邊找鬼。 笑死壁涎,一個(gè)胖子當(dāng)著我的面吹牛凡恍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播怔球,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼嚼酝,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了竟坛?” 一聲冷哼從身側(cè)響起闽巩,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎担汤,沒(méi)想到半個(gè)月后涎跨,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡崭歧,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年六敬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片驾荣。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖普泡,靈堂內(nèi)的尸體忽然破棺而出播掷,到底是詐尸還是另有隱情,我是刑警寧澤撼班,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布歧匈,位于F島的核電站,受9級(jí)特大地震影響砰嘁,放射性物質(zhì)發(fā)生泄漏件炉。R本人自食惡果不足惜勘究,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望斟冕。 院中可真熱鬧口糕,春花似錦、人聲如沸磕蛇。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)秀撇。三九已至超棺,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間呵燕,已是汗流浹背棠绘。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留再扭,地道東北人氧苍。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像霍衫,于是被迫代替她去往敵國(guó)和親候引。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容