jQuery 3.3

.find()




jquery

.find (selector) Returns: jQuery

الوصف: احصل على أحفاد كل عنصر في المجموعة الحالية من العناصر المتطابقة ، التي تمت تصفيتها بواسطة محدد ، أو كائن jQuery ، أو عنصر.

  • الإصدار المضافة: 1.0 محدد (محدد)

    • منتخب
      النوع: Selector
      سلسلة تحتوي على تعبير محدد لمطابقة العناصر.
  • الإصدار المضافة: 1.6 .find (عنصر)

    • جزء
      النوع: Element أو jQuery
      عنصر أو كائن jQuery لمطابقة العناصر في مقابل.

بالنظر إلى كائن jQuery الذي يمثل مجموعة من عناصر DOM ، تسمح لنا طريقة .find() بالبحث من خلال أحفاد هذه العناصر في شجرة DOM وإنشاء كائن jQuery جديد من العناصر المطابقة. .find() و .find() ، باستثناء أن الأخير لا ينتقل إلا إلى مستوى واحد أسفل شجرة DOM.

يقبل التوقيع الأول .find() تعبير محدد من نفس النوع الذي يمكننا تمريره إلى الدالة $() . سيتم تصفية العناصر عن طريق اختبار ما إذا كانت تطابق هذا المحدد. تتضمن التعبيرات المسموح بها محددات مثل > p والتي ستجد جميع الفقرات التي هي من عناصر العناصر في كائن jQuery.

فكر في صفحة بها قائمة متداخلة أساسية عليها:

<ul class="level-1">
  <li class="item-i">I</li>
  <li class="item-ii">II
    <ul class="level-2">
      <li class="item-a">A</li>
      <li class="item-b">B
        <ul class="level-3">
          <li class="item-1">1</li>
          <li class="item-2">2</li>
          <li class="item-3">3</li>
        </ul>
      </li>
      <li class="item-c">C</li>
    </ul>
  </li>
  <li class="item-iii">III</li>
</ul>

إذا بدأنا في البند الثاني ، فيمكننا العثور على عناصر القائمة داخلها:

$( "li.item-ii" ).find( "li" ).css( "background-color", "red" );

نتيجة هذه المكالمة هي خلفية حمراء على البنود أ ، ب ، 1 ، 2 ، 3 ، و ج. على الرغم من أن البند الثاني يطابق تعبير المحدد ، إلا أنه غير مدرج في النتائج ؛ فقط الأحفاد يعتبرون مرشحين للمباراة.

بخلاف معظم طرق traversal tree ، يكون التعبير selector مطلوبًا في استدعاء .find() . إذا احتجنا إلى استرداد جميع العناصر الفرعية ، فيمكننا المرور في المحدد العالمي '*' لإنجاز ذلك.

يتم تطبيق سياق محدد باستخدام method; .find() method; لذلك ، $( "li.item-ii" ).find( "li" ) يعادل $( "li", "li.item-ii" ) .

اعتبارًا من jQuery 1.6 ، يمكننا أيضًا تصفية التحديد مع مجموعة jQuery أو عنصر معين. مع نفس القائمة المتداخلة كما هو موضح أعلاه ، إذا بدأنا بما يلي:

var allListElements = $( "li" );

ثم مرر كائن jQuery هذا للبحث عن:

$( "li.item-ii" ).find( allListElements );

سيؤدي هذا إلى إرجاع مجموعة jQuery تحتوي فقط على عناصر القائمة التي هي نسل من البند الثاني.

وبالمثل ، يمكن أيضًا تمرير عنصر للعثور على:

var item1 = $( "li.item-1" )[ 0 ];
$( "li.item-ii" ).find( item1 ).css( "background-color", "red" );

ستكون نتيجة هذه المكالمة خلفية حمراء على العنصر 1.

أمثلة:

يبدأ مع جميع الفقرات وعمليات البحث الخاصة بعناصر الامتداد التابعة ، مثل $( "p span" )

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>find demo</title>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
 
<p><span>Hello</span>, how are you?</p>
<p>Me? I'm <span>good</span>.</p>
 
<script>
$( "p" ).find( "span" ).css( "color", "red" );
</script>
 
</body>
</html>

عرض:

اختيار باستخدام مجموعة jQuery لجميع علامات span. يتم تغيير المسافات بين علامات p إلى اللون الأحمر بينما يتم تركها باللون الأزرق.

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>find demo</title>
  <style>
  span {
    color: blue;
  }
  </style>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
 
<p><span>Hello</span>, how are you?</p>
<p>Me? I'm <span>good</span>.</p>
<div>Did you <span>eat</span> yet?</div>
 
<script>
var spans = $( "span" );
$( "p" ).find( spans ).css( "color", "red" );
</script>
 
</body>
</html>

عرض:

أضف spans حول كل كلمة ثم أضف كلمة hover وأضف إلى الكلمة m.

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>find demo</title>
  <style>
  p {
    font-size: 20px;
    width: 200px;
    color: blue;
    font-weight: bold;
    margin: 0 10px;
  }
  .hilite {
    background: yellow;
  }
  </style>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
 
<p>
  When the day is short
  find that which matters to you
  or stop believing
</p>
 
<script>
var newText = $( "p" ).text().split( " " ).join( "</span> <span>" );
newText = "<span>" + newText + "</span>";
 
$( "p" )
  .html( newText )
  .find( "span" )
    .hover(function() {
      $( this ).addClass( "hilite" );
    }, function() {
      $( this ).removeClass( "hilite" );
    })
  .end()
  .find( ":contains('t')" )
    .css({
      "font-style": "italic",
      "font-weight": "bolder"
    });
</script>
 
</body>
</html>

عرض: