• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            socketref,再見!高德

            https://github.com/adoggie

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              246 Posts :: 4 Stories :: 312 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(54)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            開始抓yixun.com的商品信息,開始很開心,但一下子來了問題。

            http請求回來的商品分類條目用<a href=>, 但這個href不能直接使用,因為頁面加載之后會啟動js程序(一般都是jquery)對頁面element進行配置和處理,例如:設置風格、事件等等。 

            yixun玩了個防頁面過期的小技巧:
               >每個請求page在server都會產生一個有效期變量XY(具體算法不詳),
               >如果獲取商品<a>直接請求,server將返回失敗,因為<a href>并未包含XY
               >page加載完成之后js代碼設置<a>被點擊時觸發事件E,E將XY添加到<a href>內
               >然后可以正確請求了


            易迅防止請求頁面過期,在主頁中設置了一下參數: 
            <script type="text/javascript"> window.yPageId = '17384560'; window.yPageLevel = '2';</script>

            在頁面內容中顯示
            <a ytag="40037" target="_blank">路由器</a>
            注意: 返回的html就是如此

            但如果用戶點擊(左鍵或者右鍵)此 node對象時,js代碼會動態插入一個YTAG的變量 

            未點擊:
            <a ytag="40037" target="_blank">路由器</a>

            點擊:   
            <a ytag="40037" target="_blank">路由器</a>

            變量生成方式在這個js中實現:

            此js 使用了jquery,頁面完成加載之后,將配置頁面元素的onclick行為,如果點擊了頁面元素,將YTAG屬性加入到商品<a href=""/>中去 
            js代碼凌亂可以使用:
            進行格式化觀察

            js代碼:

            G.header.search = {
                init: function() {
                    G.header.search.event();
                    G.header.search.setInputStyle();
                    G.header.search.autoComplete();
                },
            G.header.search.init();
            query: function() {
                    var input = $("#q_show"),
                    v = $.trim(input.val()),
                    c = $("#cate_show").val(),
                    ret = true,
                    href = input.attr("_href");
                    if (v === G.header._Q_SHOW_DEF_TEXT && href) {
                        window.location.href = href;
                        ret = false;
                    } else if (v === "" || v === G.header._Q_SHOW_DEF_TEXT) {
                        if (!|| (c && c == "")) {
                            input.focus();
                            ret = false;
                        }
                    }
                    if ($('#q_show').parents("form").find('input[name="YTAG"]').length === 0) {
                        var ytag = $('#q_show').parents("form").find('input[type="submit"]').attr("ytag");
                        var YTAG = (window.yPageLevel || 0+ '.' + (window.yPageId || 0+ ytag;
                        $('#q_show').parents("form").append($('<input type="hidden" name="YTAG" value="' + YTAG + '" />'));
                    }
                    return ret;
                }

            程序定義了G.header.search對象,并進行初始化init() ,query()是用戶點擊查詢時觸發使用 
            init()內部配置了query函數,用于鼠標點擊時候生成YTAG屬性
            看代碼就很簡單了

            YTAG生成方式就是 window.yPageLevel+'.'+window.yPageId + <a ytag="40037">
            這樣一個商品條目的href就獲得了
            posted on 2014-05-19 21:30 放屁阿狗 閱讀(1675) 評論(0)  編輯 收藏 引用
            岛国搬运www久久| 香蕉久久夜色精品升级完成| 精品久久久久久久| 国产69精品久久久久99| 一级女性全黄久久生活片免费| 性欧美丰满熟妇XXXX性久久久| 久久99精品国产| 亚洲午夜久久久久久久久电影网| 国产一久久香蕉国产线看观看 | 久久国产精品77777| 婷婷久久综合九色综合98| 久久人人爽人人精品视频| 国产成年无码久久久久毛片| 久久se精品一区二区影院| 99久久无色码中文字幕人妻| 精品久久久久中文字幕一区| 狠狠色婷婷久久综合频道日韩| 伊人丁香狠狠色综合久久| 亚洲国产精品一区二区久久hs| 久久久久噜噜噜亚洲熟女综合| 久久精品中文字幕无码绿巨人| 亚洲国产成人乱码精品女人久久久不卡| 韩国免费A级毛片久久| 国产69精品久久久久久人妻精品| 久久99精品久久久久久齐齐| 九九精品99久久久香蕉| 亚洲欧美成人综合久久久| 亚洲性久久久影院| 久久久久久国产精品免费免费| 色综合久久88色综合天天| 99久久精品国产高清一区二区| 久久香综合精品久久伊人| 久久精品人人做人人爽电影| 无码八A片人妻少妇久久| 久久婷婷午色综合夜啪| 久久青青草原精品国产软件| 久久久久无码精品| 久久精品成人免费国产片小草| 国产—久久香蕉国产线看观看 | 久久亚洲AV成人无码电影| 久久久精品2019免费观看|