الفرق بين المراجعتين لصفحة: «jQuery/add»
Khaled-yassin (نقاش | مساهمات) أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE:التابع <code>.add()</code> في jQuery}}</noinclude> == <code>.add(...' |
|||
(5 مراجعات متوسطة بواسطة نفس المستخدم غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE:التابع <code>.add()</code> في jQuery}}</noinclude> | <noinclude>{{DISPLAYTITLE:التابع <code>.add()</code> في jQuery}}</noinclude> | ||
== <code>.add( selector )</code> == | == <code>.add( selector )</code> == | ||
سطر 13: | سطر 12: | ||
==== <code>selector</code> ==== | ==== <code>selector</code> ==== | ||
سلسلة من النوع | سلسلة من النوع Selector تمثل تعبير مُحدِّد للعثور على عناصر إضافية لإضافتها إلى مجموعة العناصر المطابقة. | ||
=== <code>.add( elements )</code> === | === <code>.add( elements )</code> === | ||
سطر 19: | سطر 18: | ||
==== <code>elements</code> ==== | ==== <code>elements</code> ==== | ||
عنصر واحد أو أكثر من النوع [[ | عنصر واحد أو أكثر من النوع [[JavaScript/Element|Element]] لإضافته إلى مجموعة العناصر المطابقة. | ||
=== <code>.add( html )</code> === | === <code>.add( html )</code> === | ||
سطر 25: | سطر 24: | ||
==== <code>html</code> ==== | ==== <code>html</code> ==== | ||
جزء من شيفرة HTML لإضافته إلى مجموعة العناصر المطابقة وهو من النوع <code>[[ | جزء من شيفرة HTML لإضافته إلى مجموعة العناصر المطابقة وهو من النوع <code>[[JavaScript/String|String]]</code>. | ||
=== <code>.add( selection )</code> === | === <code>.add( selection )</code> === | ||
سطر 40: | سطر 39: | ||
==== <code>context</code> ==== | ==== <code>context</code> ==== | ||
النقطة في المستند التي يجب أن يبدأ عندها المُحدِّد في المطابقة؛ وهي مشابهة لوسيط السياق الخاص بالتابع <code>$(selector, context)</code> وهو من النوع [[ | النقطة في المستند التي يجب أن يبدأ عندها المُحدِّد في المطابقة؛ وهي مشابهة لوسيط السياق الخاص بالتابع <code>$(selector, context)</code> وهو من النوع [[JavaScript/Element|Element]]. | ||
ولما كان كائن jQuery يمثل مجموعة من عناصر DOM، | ولما كان كائن jQuery يمثل مجموعة من عناصر DOM، ينُشِئ التابع <code>.add()</code> كائن jQuery جديد من اتحاد تلك العناصر وتلك التي مُرِرت إلى التابع. إلى حد كبير، يمكن أن يكون الوسيط المُدخل إلى التابع <code>.add()</code> أي شيء يقبله <code>$()</code>، بما في ذلك تعبير مُحدِّد jQuery، أو مراجع لعناصر DOM، أو مقتطف من شيفرة HTML. | ||
لا تفترض أن يُلحق هذا التابع العناصرَ إلى المجموعة الموجودة بالترتيب الذي مُرِرت به إلى التابع <code>.add()</code>. عندما تكون كافة العناصر أعضاء في نفس المستند، ستترتب المجموعة الناتجة من التابع <code>.add()</code> بترتيب المستند؛ أي حسب ظهور كل عنصر في المستند. إذا كانت المجموعة تتكون من عناصر من مستندات مختلفة أو من عناصر غير الموجودة في أي مستند، فإن الترتيب يكون غير محدد. | لا تفترض أن يُلحق هذا التابع العناصرَ إلى المجموعة الموجودة بالترتيب الذي مُرِرت به إلى التابع <code>.add()</code>. عندما تكون كافة العناصر أعضاء في نفس المستند، ستترتب المجموعة الناتجة من التابع <code>.add()</code> بترتيب المستند؛ أي حسب ظهور كل عنصر في المستند. إذا كانت المجموعة تتكون من عناصر من مستندات مختلفة أو من عناصر غير الموجودة في أي مستند، فإن الترتيب يكون غير محدد. | ||
سطر 48: | سطر 47: | ||
لإنشاء كائن jQuery بعناصر مُرتَبة بترتيب مُعرّف بشكل جيد وبدون حٍمل عملية الترتيب يستخدم الشكل <code>$(array_of_DOM_elements)</code>. | لإنشاء كائن jQuery بعناصر مُرتَبة بترتيب مُعرّف بشكل جيد وبدون حٍمل عملية الترتيب يستخدم الشكل <code>$(array_of_DOM_elements)</code>. | ||
يمكن استخدام المجموعة المحدّثة من العناصر في | يمكن استخدام المجموعة المحدّثة من العناصر في سلسلة (chain)، أو تعيينها لمتغير لاستخدامه لاحقًا. ومثال على ذلك:<syntaxhighlight lang="jquery"> | ||
$( "p" ).add( "div" ).addClass( "widget" ); | $( "p" ).add( "div" ).addClass( "widget" ); | ||
var pdiv = $( "p" ).add( "div" ); | var pdiv = $( "p" ).add( "div" ); | ||
سطر 54: | سطر 53: | ||
var pdiv = $( "p" ); | var pdiv = $( "p" ); | ||
pdiv.add( "div" ); // خطأ، pdiv لن يتغير | pdiv.add( "div" ); // خطأ، pdiv لن يتغير | ||
</syntaxhighlight>الصفحة التالية تحتوي على قائمة بسيطة ثم فقرة تليها:<syntaxhighlight lang="html"> | </syntaxhighlight>الصفحة التالية تحتوي على قائمة <code>[[HTML/ul|<nowiki><ul></nowiki>]]</code> بسيطة ثم فقرة <code>[[HTML/p|<nowiki><p></nowiki>]]</code> تليها:<syntaxhighlight lang="html"> | ||
<ul> | <ul> | ||
<li>البند رقم 1</li> | <li>البند رقم 1</li> | ||
سطر 63: | سطر 62: | ||
</syntaxhighlight>يمكننا تحديد عناصر القائمة ثم الفقرة باستخدام إما محدد أو مرجع لعنصر DOM نفسه كوسيط للتابع <code>.add()</code>:<syntaxhighlight lang="jquery"> | </syntaxhighlight>يمكننا تحديد عناصر القائمة ثم الفقرة باستخدام إما محدد أو مرجع لعنصر DOM نفسه كوسيط للتابع <code>.add()</code>:<syntaxhighlight lang="jquery"> | ||
$( "li" ).add( "p" ).css( "background-color", "red" ); | $( "li" ).add( "p" ).css( "background-color", "red" ); | ||
</syntaxhighlight>أو<syntaxhighlight lang="jquery"> | </syntaxhighlight>أو:<syntaxhighlight lang="jquery"> | ||
$( "li" ).add( document.getElementsByTagName( "p" )[ 0 ] ) | $( "li" ).add( document.getElementsByTagName( "p" )[ 0 ] ) | ||
.css( "background-color", "red" ); | .css( "background-color", "red" ); | ||
</syntaxhighlight>ينتج عن هذا الاستدعاء خلفية حمراء خلف جميع العناصر الأربعة. باستخدام مقتطف HTML كوسيط للتابع <code>.add()</code> (كما هو الحال في الإصدار الثالثة)، يمكننا إنشاء عناصر إضافية مباشرةً وإضافة تلك العناصر إلى مجموعة العناصر المطابقة. | </syntaxhighlight>ينتج عن هذا الاستدعاء ضبط خلفية حمراء خلف جميع العناصر الأربعة. باستخدام مقتطف HTML كوسيط للتابع <code>.add()</code> (كما هو الحال في الإصدار الثالثة)، يمكننا إنشاء عناصر إضافية مباشرةً وإضافة تلك العناصر إلى مجموعة العناصر المطابقة. | ||
على الرغم من إنشاء الفقرة الجديدة وتغيير لون خلفيتها، إلا أنها لا تظهر في الصفحة. لوضعها على الصفحة، يمكننا إضافة أحد توابع الإدراج إلى السلسلة. | على الرغم من إنشاء الفقرة الجديدة وتغيير لون خلفيتها، إلا أنها لا تظهر في الصفحة. لوضعها على الصفحة، يمكننا إضافة أحد توابع الإدراج إلى السلسلة. | ||
بدءًا من jQuery 1.4 ستُعاد دوماً نتائج التابع <code>.add()</code> في ترتيب المستند (بدلاً من تسلسل بسيط). | |||
ملاحظة: لعكس تأثير التابع <code>.add()</code> يمكنك استخدام التابع <code>.not( elements | selector )</code> لإزالة عناصر من نتائج jQuery أو التابع <code>.end()</code> للعودة إلى التحديد قبل إضافتك. | ملاحظة: لعكس تأثير التابع <code>.add()</code> يمكنك استخدام التابع <code>[[jQuery/not|.not( elements | selector )]]</code> لإزالة عناصر من نتائج jQuery أو التابع <code>[[jQuery/end|.end()]]</code> للعودة إلى التحديد قبل إضافتك. | ||
== أمثلة == | == أمثلة == | ||
العثور على جميع عناصر<code><nowiki><div></nowiki></code> وعمل إطار. ثم إضافة كل الفقرات إلى كائن jQuery لضبط خلفياتها إلى اللون الأصفر | العثور على جميع عناصر <code>[[HTML/div|<nowiki><div></nowiki>]]</code> وعمل إطار. ثم إضافة كل الفقرات إلى كائن jQuery لضبط خلفياتها إلى اللون الأصفر:<syntaxhighlight lang="html"> | ||
<!doctype html> | <!doctype html> | ||
<html lang="en"> | <html lang="en"> | ||
سطر 118: | سطر 117: | ||
</body> | </body> | ||
</html> | </html> | ||
</syntaxhighlight>إضافة المزيد من العناصر، المُطابِقة لتعبيرٍ محدد، إلى مجموعة العناصر المطابقة | </syntaxhighlight>إضافة المزيد من العناصر، المُطابِقة لتعبيرٍ محدد، إلى مجموعة العناصر المطابقة:<syntaxhighlight lang="html"> | ||
<!doctype html> | <!doctype html> | ||
<html lang="en"> | <html lang="en"> | ||
سطر 137: | سطر 136: | ||
</body> | </body> | ||
</html> | </html> | ||
</syntaxhighlight>إضافة المزيد من العناصر، التي أُنشأت مباشرة، إلى مجموعة العناصر المُطابقة | </syntaxhighlight>إضافة المزيد من العناصر، التي أُنشأت مباشرة، إلى مجموعة العناصر المُطابقة:<syntaxhighlight lang="html"> | ||
<!doctype html> | <!doctype html> | ||
<html lang="en"> | <html lang="en"> | ||
سطر 155: | سطر 154: | ||
</body> | </body> | ||
</html> | </html> | ||
</syntaxhighlight>إضافة عنصر أو أكثر إلى مجموعة العناصر المُطابقة | </syntaxhighlight>إضافة عنصر أو أكثر إلى مجموعة العناصر المُطابقة:<syntaxhighlight lang="html"> | ||
<!doctype html> | <!doctype html> | ||
<html lang="en"> | <html lang="en"> | ||
سطر 174: | سطر 173: | ||
</body> | </body> | ||
</html> | </html> | ||
</syntaxhighlight>يوضح كيفية إضافة (أو دفع) عناصر إلى مجموعة موجودة. | </syntaxhighlight>يوضح كيفية إضافة (أو دفع) عناصر إلى مجموعة موجودة:<syntaxhighlight lang="html"> | ||
<!doctype html> | |||
<html lang="en"> | |||
<head> | |||
<meta charset="utf-8"> | |||
<title>add مثال على التابع</title> | |||
<script src="https://code.jquery.com/jquery-1.10.2.js"></script> | |||
</head> | |||
<body> | |||
<p>مرحبًا</p> | |||
<span id="a">مرحبًا مرة أخرى</span> | |||
<script> | |||
var collection = $( "p" ); | |||
collection = collection.add( document.getElementById( "a" ) ); | |||
collection.css( "background", "yellow" ); | |||
</script> | |||
</body> | |||
</html> | |||
</syntaxhighlight> | |||
== مصادر == | == مصادر == | ||
* [http://api.jquery.com/add/ صفحة التابع .add()في توثيق jQuery الرسمي]. | * [http://api.jquery.com/add/ صفحة التابع .add()في توثيق jQuery الرسمي]. |
المراجعة الحالية بتاريخ 13:19، 1 يوليو 2018
.add( selector )
القيمة المعادة
يُعيد كائنًا من النوع jQuery.
الوصف
إنشاء كائن jQuery جديد من العناصر المضافة إلى مجموعة من العناصر المطابقة.
add( selector )
أُضيف مع الإصدار: 1.0.
selector
سلسلة من النوع Selector تمثل تعبير مُحدِّد للعثور على عناصر إضافية لإضافتها إلى مجموعة العناصر المطابقة.
.add( elements )
أُضيف مع الإصدار: 1.0.
elements
عنصر واحد أو أكثر من النوع Element لإضافته إلى مجموعة العناصر المطابقة.
.add( html )
أُضيف مع الإصدار: 1.0.
html
جزء من شيفرة HTML لإضافته إلى مجموعة العناصر المطابقة وهو من النوع String
.
.add( selection )
أُضيف مع الإصدار: 1.3.2.
selection
كائن موجود من النوع jQuery لإضافته إلى مجموعة العناصر المطابقة.
.add( selector, context )
أُضيف مع الإصدار: 1.4.
selector
سلسلة من النوع Selector تمثل تعبير مُحدِّد للعثور على عناصر إضافية لإضافتها إلى مجموعة العناصر المطابقة.
context
النقطة في المستند التي يجب أن يبدأ عندها المُحدِّد في المطابقة؛ وهي مشابهة لوسيط السياق الخاص بالتابع $(selector, context)
وهو من النوع Element.
ولما كان كائن jQuery يمثل مجموعة من عناصر DOM، ينُشِئ التابع .add()
كائن jQuery جديد من اتحاد تلك العناصر وتلك التي مُرِرت إلى التابع. إلى حد كبير، يمكن أن يكون الوسيط المُدخل إلى التابع .add()
أي شيء يقبله $()
، بما في ذلك تعبير مُحدِّد jQuery، أو مراجع لعناصر DOM، أو مقتطف من شيفرة HTML.
لا تفترض أن يُلحق هذا التابع العناصرَ إلى المجموعة الموجودة بالترتيب الذي مُرِرت به إلى التابع .add()
. عندما تكون كافة العناصر أعضاء في نفس المستند، ستترتب المجموعة الناتجة من التابع .add()
بترتيب المستند؛ أي حسب ظهور كل عنصر في المستند. إذا كانت المجموعة تتكون من عناصر من مستندات مختلفة أو من عناصر غير الموجودة في أي مستند، فإن الترتيب يكون غير محدد.
لإنشاء كائن jQuery بعناصر مُرتَبة بترتيب مُعرّف بشكل جيد وبدون حٍمل عملية الترتيب يستخدم الشكل $(array_of_DOM_elements)
.
يمكن استخدام المجموعة المحدّثة من العناصر في سلسلة (chain)، أو تعيينها لمتغير لاستخدامه لاحقًا. ومثال على ذلك:
$( "p" ).add( "div" ).addClass( "widget" );
var pdiv = $( "p" ).add( "div" );
التالي لن يحفظ العناصر المضافة، لأن التابع .add()
ينشيء مجموعة جديدة ويترك المجموعة الأصلية في pdiv
دون تغيير:
var pdiv = $( "p" );
pdiv.add( "div" ); // خطأ، pdiv لن يتغير
الصفحة التالية تحتوي على قائمة <ul>
بسيطة ثم فقرة <p>
تليها:
<ul>
<li>البند رقم 1</li>
<li>البند رقم 2</li>
<li>البند رقم 3</li>
</ul>
<p>فقرة</p>
يمكننا تحديد عناصر القائمة ثم الفقرة باستخدام إما محدد أو مرجع لعنصر DOM نفسه كوسيط للتابع .add()
:
$( "li" ).add( "p" ).css( "background-color", "red" );
أو:
$( "li" ).add( document.getElementsByTagName( "p" )[ 0 ] )
.css( "background-color", "red" );
ينتج عن هذا الاستدعاء ضبط خلفية حمراء خلف جميع العناصر الأربعة. باستخدام مقتطف HTML كوسيط للتابع .add()
(كما هو الحال في الإصدار الثالثة)، يمكننا إنشاء عناصر إضافية مباشرةً وإضافة تلك العناصر إلى مجموعة العناصر المطابقة.
على الرغم من إنشاء الفقرة الجديدة وتغيير لون خلفيتها، إلا أنها لا تظهر في الصفحة. لوضعها على الصفحة، يمكننا إضافة أحد توابع الإدراج إلى السلسلة.
بدءًا من jQuery 1.4 ستُعاد دوماً نتائج التابع .add()
في ترتيب المستند (بدلاً من تسلسل بسيط).
ملاحظة: لعكس تأثير التابع .add()
يمكنك استخدام التابع .not( elements | selector )
لإزالة عناصر من نتائج jQuery أو التابع .end()
للعودة إلى التحديد قبل إضافتك.
أمثلة
العثور على جميع عناصر <div>
وعمل إطار. ثم إضافة كل الفقرات إلى كائن jQuery لضبط خلفياتها إلى اللون الأصفر:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>add مثال على التابع</title>
<style>
div {
width: 60px;
height: 60px;
margin: 10px;
float: left;
}
p {
clear: left;
font-weight: bold;
font-size: 16px;
color: blue;
margin: 0 10px;
padding: 2px;
}
</style>
<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<p>هذه الفقرة أضيفت ... (لاحظ أنها بلا إطار)</p>
<script>
$( "div" ).css( "border", "2px solid red" )
.add( "p" )
.css( "background", "yellow" );
</script>
</body>
</html>
إضافة المزيد من العناصر، المُطابِقة لتعبيرٍ محدد، إلى مجموعة العناصر المطابقة:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>add مثال على التابع</title>
<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
<p>مرحبًا</p>
<span>مرحبًا مرة أخرى</span>
<script>
$( "p" ).add( "span" ).css( "background", "yellow" );
</script>
</body>
</html>
إضافة المزيد من العناصر، التي أُنشأت مباشرة، إلى مجموعة العناصر المُطابقة:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>add مثال على التابع</title>
<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
<p>مرحبًا</p>
<script>
$( "p" ).clone().add( "<span>مرة أخرى</span>" ).appendTo( document.body );
</script>
</body>
</html>
إضافة عنصر أو أكثر إلى مجموعة العناصر المُطابقة:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>add مثال على التابع</title>
<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
<p>مرحبًا</p>
<span id="a">مرحبًا مرة أخرى</span>
<script>
$( "p" ).add( document.getElementById( "a" ) ).css( "background", "yellow" );
</script>
</body>
</html>
يوضح كيفية إضافة (أو دفع) عناصر إلى مجموعة موجودة:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>add مثال على التابع</title>
<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
<p>مرحبًا</p>
<span id="a">مرحبًا مرة أخرى</span>
<script>
var collection = $( "p" );
collection = collection.add( document.getElementById( "a" ) );
collection.css( "background", "yellow" );
</script>
</body>
</html>