2012-01-04 5 views
7
<div id="myDiv" class=" blueberry mango "></div> 

Nếu chúng ta sử dụng .addClass()Có lý do cụ thể nào khiến addClass của jQuery() không phải là trang trí đúng không?

$("#myDiv").addClass("carrot"); 

Lớp cho myDiv tại là "(no-space)blueberry mango(double-space)carrot"

Có một left-trim, nhưng có không gian đôi giữa xoài và cà rốt vì không có right-trim

  • Có lý do cụ thể nào khiến jQuery làkhôngkhông phải là phải cắt tỉa?
  • Hoặc cắt bên trái thậm chí không được dự định?
+1

Tôi đoán nó đã làm với tốc độ. Điều này có gây ra lỗi không? – sissonb

+3

Điều này không nên gây ra bất kỳ lỗi nào, vì vậy nó thực sự quan trọng? –

+0

Tuy nhiên, đây là một câu hỏi thú vị. – PeeHaa

Trả lời

7

Dường như jQuery đang thực hiện cắt sau khi thêm lớp học. Xem jquery đang addClass dưới đây,

addClass: function(value) { 
    var classNames, i, l, elem, 
     setClass, c, cl; 

    if (jQuery.isFunction(value)) { 
     return this.each(function(j) { 
      jQuery(this).addClass(value.call(this, j, this.className)); 
     }); 
    } 

    if (value && typeof value === "string") { 
     classNames = value.split(rspace); 

     for (i = 0, l = this.length; i < l; i++) { 
      elem = this[ i ]; 

      if (elem.nodeType === 1) { 
       if (!elem.className && classNames.length === 1) { 
        elem.className = value; 

       } else { 
       //HERE IS APPENDS ALL CLASS IT NEEDS TO ADD 
        setClass = " " + elem.className + " "; 

        for (c = 0, cl = classNames.length; c < cl; c++) { 
         if (!~setClass.indexOf(" " + classNames[ c ] + " ")) { 
          setClass += classNames[ c ] + " "; 
         } 
        } 
        elem.className = jQuery.trim(setClass); 
       } 
      } 
     } 
    } 

    return this; 
} 

Vì vậy, nó giống như dưới đây,

jQuery.trim(" blueberry mango " + " " + "carrot")

2

Điều này xảy ra vì jQuery đang thêm lớp vào danh sách các lớp và sau đó chạy trim trên toàn bộ chuỗi.

Hãy xem qua số source for addClass để xem điều gì đang xảy ra.

0

Nhìn vào nguồn, tôi đoán không có lý do cho điều đó:

setClass = " " + elem.className + " "; 

for (c = 0, cl = classNames.length; c < cl; c++) { 
    if (!~setClass.indexOf(" " + classNames[ c ] + " ")) { 
     setClass += classNames[ c ] + " "; 
    } 
} 
elem.className = jQuery.trim(setClass); 

Đúng , có khoảng trống trước và sau mỗi lớp giúp tìm xem lớp mới (đang được thêm) đã có hay không, nhưng chúng vẫn có thể thay thế dòng đầu tiên bằng:

setClass = " " + jQuery.trim(elem.className) + " "; 

và nó vẫn sẽ làm việc cùng một cách ...