bootstrap源碼學習與示例:bootstrap-alert


bootstrap-alert組件基本活兒在CSS上,JS部分就是一個關閉事件。這是框架提供的關閉事件,在這之前,你可以通過on方法綁定close,closed這兩種回調,它會在關閉時被調用。基本上,你只要引入了JS文件,HTML按它格式要求寫,它就能干活了。

需要注意的有兩個:

  • 關閉銨鈕必須帶data-dismiss="alert"屬性
  • 關閉時事件必須要綁定在UI容器上,而不是關閉按鈕中
!function ($) {

    "use strict"; // jshint ;_;
    /* ALERT CLASS DEFINITION
  * ====================== */
    //這是程序員風格的命名
    var dismiss = '[data-dismiss="alert"]'
    , Alert = function (el) {
        $(el).on('click', dismiss, this.close)
    }
    //它最要的方法 
    Alert.prototype.close = function (e) {
        //獲取這個控件對應的DOM
        //分別通過以下三個途徑:
        //1 data-target自定義屬性 
        //2 href的屬性中的hash(多為簡單的ID選擇器或類選擇器), 
        //3這個按鈕的直屬父節點
        var $this = $(this)
        , selector = $this.attr('data-target')
        , $parent
        if (!selector) {
            selector = $this.attr('href')
            selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
        }
        $parent = $(selector)

        e && e.preventDefault()

        $parent.length || ($parent = $this.hasClass('alert') ? $this : $this.parent())

        $parent.trigger(e = $.Event('close'))
        //在移除前觸發close自定義事件

        if (e.isDefaultPrevented()) return
        //觸發CSS3的fade效果,它要與fade類名組合使用
        $parent.removeClass('in')

        function removeElement() {
            $parent
            .trigger('closed')
            .remove()
        //在移除后觸發closed自定義事件
        }

        $.support.transition && $parent.hasClass('fade') ?
        $parent.on($.support.transition.end, removeElement) :
        removeElement()
    }


    /* ALERT PLUGIN DEFINITION
  * ======================= */

    var old = $.fn.alert

    $.fn.alert = function (option) {
        return this.each(function () {
            var $this = $(this)
            , data = $this.data('alert')
            //重復利用實例
            if (!data) $this.data('alert', (data = new Alert(this)))
            //從目前Alert實例的原型來看,這個option只能為close
            if (typeof option == 'string') data[option].call($this)
        })
    }

    $.fn.alert.Constructor = Alert


    /* ALERT NO CONFLICT
  * ================= */

    $.fn.alert.noConflict = function () {
        $.fn.alert = old
        return this
    }

    /* ALERT DATA-API
  * ============== */
    //綁定關閉事件
    $(document).on('click.alert.data-api', dismiss, Alert.prototype.close)

}(window.jQuery);

alert組件的外形是通過以下三組類名決定的。首先alert是必須的,alert-block是決定它內部是否能多行,還有一種決定皮膚,暫時只有三種:alert-success, alert-danger, alert-info

以下是它對應的less。

//
// Alerts
// --------------------------------------------------


// Base styles
// -------------------------

.alert {
  padding: 8px 35px 8px 14px;
  margin-bottom: @baseLineHeight;
  text-shadow: 0 1px 0 rgba(255,255,255,.5);
  background-color: @warningBackground;
  border: 1px solid @warningBorder;
  .border-radius(@baseBorderRadius);
}
.alert,
.alert h4 {
  // Specified for the h4 to prevent conflicts of changing @headingsColor
  color: @warningText;
}
.alert h4 {
  margin: 0;
}

// Adjust close link position
.alert .close {
  position: relative;
  top: -2px;
  right: -21px;
  line-height: @baseLineHeight;
}


// Alternate styles
// -------------------------

.alert-success {
  background-color: @successBackground;
  border-color: @successBorder;
  color: @successText;
}
.alert-success h4 {
  color: @successText;
}
.alert-danger,
.alert-error {
  background-color: @errorBackground;
  border-color: @errorBorder;
  color: @errorText;
}
.alert-danger h4,
.alert-error h4 {
  color: @errorText;
}
.alert-info {
  background-color: @infoBackground;
  border-color: @infoBorder;
  color: @infoText;
}
.alert-info h4 {
  color: @infoText;
}


// Block alerts
// -------------------------

.alert-block {
  padding-top: 14px;
  padding-bottom: 14px;
}
.alert-block > p,
.alert-block > ul {
  margin-bottom: 0;
}
.alert-block p + p {
  margin-top: 5px;
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM