茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    jQuery+ajax實現(xiàn)實用的點贊插件代碼
    來源:易賢網(wǎng) 閱讀:2669 次 日期:2016-07-25 16:19:49
    溫馨提示:易賢網(wǎng)小編為您整理了“jQuery+ajax實現(xiàn)實用的點贊插件代碼”,方便廣大網(wǎng)友查閱!

    本文給大家分享的是作者在自己的博客上使用jQuery+ajax實現(xiàn)實用的點贊插件代碼,這里推薦給大家,希望對大家能夠有所幫助。

    之前給大家總結(jié)了jQuery插件開發(fā)的兩種方式,這里就實踐一下,做一款點贊特效插件,先看看效果吧:

    名單

    上代碼:

    //***擴展對象點贊插件、點贊特效***//

    //***Zynblog**//

    //***2016-5-11**//

    //***用法:jQuery('.praisebtn').praise(options);***//

    ; (function ($) {

     $.fn.praise = function (options) {

      var defaults = {

       obj: null, //jq對象,針對哪個對象使用這個tipsBox函數(shù)

       str: "+1", //字符串,要顯示的內(nèi)容;也可以傳一段html,如: "<b style='font-family:Microsoft YaHei;'>哈哈</b>"

       startSize: "10px", //動畫開始的文字大小

       endSize: "30px", //動畫結(jié)束的文字大小

       interval: 600, //文字動畫時間間隔

       color: "red", //文字顏色

       callback: function () { } //回調(diào)函數(shù)

      };

      var opt = $.extend(defaults, options); //合并參數(shù)

      $("body").append("<span class='num'>" + opt.str + "</span>");

      var box = $(".num");

      var left = opt.obj.offset().left + opt.obj.width()/2; //span btn左側(cè)距離加上自身寬度的一半

      var top = opt.obj.offset().top - opt.obj.height();//頂部距離減去自身的高度

      box.css({

       "position": "absolute",

       "left": left + "px",

       "top": top + "px",

       "z-index": 9999,

       "font-size": opt.startSize,

       "line-height": opt.endSize,

       "color": opt.color

      });

      box.animate({

       "font-size": opt.endSize,

       "opacity": "0",

       "top": top - parseInt(opt.endSize) + "px"

      }, opt.interval, function () {

       box.remove();

       opt.callback();

      });

     }

    })(jQuery);

    //點贊圖標(biāo)恢復(fù)原樣

    function niceIn(prop) {

     prop.find('.praisenum').addClass('niceIn').css("color", "red");

     setTimeout(function () {

      prop.find('.praisenum').css("color", "#45BCF9").removeClass('niceIn');

     }, 1000);

    };

    用法:在需要用到點贊插件的頁面中引入jquery.js、以及這個插件.js,在$(function(){})中給"[object Object]"注冊click事件即可。

    HTML:

    <span class="praisebtn">

      <img src="/Content/images/ico_praise.png" class="praisenum" data-bd-imgshare-binded="1">

      (<a href="#" praise-flag="0" data-id="7">2</a>)

      //praise-flag="0" 記錄點贊標(biāo)識(是否已贊過),data-id記錄文章id

    </span>

    jQuery(本站并不強制訪客進行注冊登錄后才能點贊,因此并不限制訪客的點贊次數(shù)):

    //點贊特效+Ajax統(tǒng)計點贊數(shù)量

     pariseShow: function () {

      //使用自定義的點贊特效插件,在zynblog.js前要先引入這個插件

      //jquery給暫未生成的標(biāo)簽綁定事件要用on('事件','對象','事件句柄')

      jQuery(document).on("click", ".praisebtn", function (e) {

       e.preventDefault();

       //獲取被點贊文章的id praise-flag:0沒攢過,1:贊過了

       //頁面剛生成時,可以從庫中確定該用戶是否點贊,并為praise-flag屬性賦初值

       //這里沒必要那么嚴(yán)謹,所以初值均為1,(頂多是再在cookie中給個標(biāo)記)

       var praiseFlag = jQuery(this).children('a').attr('praise-flag');

       //alert(praiseFlag);

       var praiseArtId = jQuery(this).children('a').attr('data-id');

       //alert(praiseArtId);

       //1. 如果沒贊過

       if (praiseFlag == 0) {

        var curPraise = jQuery(this).children('a');

        curPraise.attr('praise-flag', "1");//先把點贊標(biāo)識的屬性值設(shè)為1

        jQuery(this).praise({

         obj: jQuery(this),

         str: "+1",

         callback: function () {

          jQuery.post("/Archives/PraiseStatic", { "artId": praiseArtId }, function (data) {

           if (data.Status == 1) {

            var praisecount = parseInt(curPraise.text().match(/\d+/));

            curPraise.text(curPraise.text().replace(praisecount, praisecount + 1));

           } else if (data.Status == 2) {

            alert(data.Message);

           } else if (data.Status == 0) {

            alert(data.Message);

           }

          });

         }

        });

        niceIn(jQuery(this));

       } else if (praiseFlag == 1) {

        //2. 如果已經(jīng)已贊

        jQuery("body").append("<span class='praisetip'>您已贊過~</span>");

        var tipbox = jQuery(".praisetip");

        var left = jQuery(this).offset().left;

        var top = jQuery(this).offset().top + jQuery(this).height();

        tipbox.css({

         "position": "absolute",

         "left": left + "px",

         "top": top + "px",

         "z-index": 9999,

         "font-size": "12px",

         "line-height": "13px",

         "color": "red"

        });

        tipbox.animate({

         "opacity": "0"

        }, 1200, function () {

         tipbox.remove();

        });

       }

      });

     },

    更多信息請查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機網(wǎng)站地址:jQuery+ajax實現(xiàn)實用的點贊插件代碼
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2026上岸·考公考編培訓(xùn)報班

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報警專用圖標(biāo)