الفرق بين المراجعتين ل"JavaScript/Document/getElementsByTagNameNS"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
(إضافة الصّفحة)
 
سطر 1: سطر 1:
 
<noinclude>{{DISPLAYTITLE:<code>Document.getElementsByTagNameNS()‎</code>}}</noinclude>
 
<noinclude>{{DISPLAYTITLE:<code>Document.getElementsByTagNameNS()‎</code>}}</noinclude>
يُعيد التّابع <code>Document.getElementsByTagNameNS()‎</code> قائمةً تحتوي على جميع العناصر ذات اسم الوسم (tag name) التّابع لمجال الأسماء (namespace) المُعطى. عند استدعائه على كائن المُستند، فسيُبحَثُ في كامل المُستند، ما يشمل العقدة الجذر.
+
يُعيد التّابع <code>Document.getElementsByTagNameNS()‎</code> قائمةً تحتوي على جميع العناصر ذات اسم الوسم (tag name) التّابع لمجال الأسماء (namespace) المعطيين. عند استدعائه على كائن المُستند، فسيُبحَثُ في كامل المُستند، ما يشمل العقدة الجذر.
  
 
==البنية العامة==
 
==البنية العامة==
سطر 12: سطر 12:
  
 
====<code>namespace‎</code>====
 
====<code>namespace‎</code>====
عنوان URI مجال الأسماء للبحث عنه (انظر <code>‎[[JavaScript/Element/namespaceURI|element.namespaceURI]]</code>).
+
عنوان URI مجال الأسماء المبحوث عنه (انظر <code>‎[[JavaScript/Element/namespaceURI|element.namespaceURI]]</code>).
  
 
====<code>name‎</code>====
 
====<code>name‎</code>====
 
سلسلةٌ نصيّةٌ تُمثّل أسماء العناصِر المبحوث عنها. السلسلة النّصيّة الخاصّة <code>"*"‎</code> تُمثّل جميع العناصر (انظر <code>‎[[JavaScript/Element/localName|element.localName]]</code>).
 
سلسلةٌ نصيّةٌ تُمثّل أسماء العناصِر المبحوث عنها. السلسلة النّصيّة الخاصّة <code>"*"‎</code> تُمثّل جميع العناصر (انظر <code>‎[[JavaScript/Element/localName|element.localName]]</code>).
  
مُلاحظة: تقول مواصفة من W3C بأنّ قيمة <code>elements‎</code> عبارةٌ عن كائن <code>[[JavaScript/NodeList|NodeList‎]]</code>، لكنّ هذا التّابع يُعيد كائنا من النّوع <code>[[JavaScript/HTMLCollection|HTMLCollection‎]]</code> في مُتصفّح Internet Explorer وFirefox. يُعيد متصفّح Opera كائن <code>[[JavaScript/NodeList|NodeList‎]]</code> ذي تابعٍ <code>namedItem</code> مُطبَّق، ما يجعل الكائن مُشابها للكائن <code>[[JavaScript/HTMLCollection|HTMLCollection‎]]</code>. يُعيد هذا التّابع كائنا صحيحًا من النّوع <code>[[JavaScript/NodeList|NodeList]]</code> فقط في مُتصفّحات WebKit (مثل Chrome وSafari). انظر العلّة [https://bugzilla.mozilla.org/show_bug.cgi?id=14869 14869] للمزيد من التّفاصيل.
+
'''مُلاحظة:''' تقول مواصفة W3C بأنّ قيمة <code>elements‎</code> عبارةٌ عن كائن <code>[[JavaScript/NodeList|NodeList‎]]</code>، لكنّ هذا التّابع يُعيد كائنا من النّوع <code>[[JavaScript/HTMLCollection|HTMLCollection‎]]</code> في مُتصفّح Internet Explorer وFirefox. يُعيد متصفّح Opera كائن <code>[[JavaScript/NodeList|NodeList‎]]</code> ذي تابعٍ <code>namedItem</code> مُطبَّق، ما يجعل الكائن مُشابها للكائن <code>[[JavaScript/HTMLCollection|HTMLCollection‎]]</code>. يُعيد هذا التّابع كائنا صحيحًا من النّوع <code>[[JavaScript/NodeList|NodeList]]</code> فقط في مُتصفّحات WebKit (مثل Chrome وSafari). انظر العلّة [https://bugzilla.mozilla.org/show_bug.cgi?id=14869 14869] للمزيد من التّفاصيل.
  
 
==أمثلة==
 
==أمثلة==
 
يبدأ التّابع <code>Document.getElementsByTagName()‎</code> في المثال التّالي من عنصرٍ أبٍ معيّنٍ ويبحث من الأعلى إلى الأسفل تعاوديًّا (recursively) عبر DOM بدايةً من العنصر الأب، بانيًّا مجموعة عناصر أولاد يُساوي اسمها المُعامل <code>name‎</code>. لاحظ أنّه عندما تكون العقدة التي يعمل عليها التّابع مُغايرةً لعقدة المُستند، فالتّابع <code>Element.getElementsByTagNameNS()‎</code> يُستَخدمُ عوضًا عن هذا التّابع.
 
يبدأ التّابع <code>Document.getElementsByTagName()‎</code> في المثال التّالي من عنصرٍ أبٍ معيّنٍ ويبحث من الأعلى إلى الأسفل تعاوديًّا (recursively) عبر DOM بدايةً من العنصر الأب، بانيًّا مجموعة عناصر أولاد يُساوي اسمها المُعامل <code>name‎</code>. لاحظ أنّه عندما تكون العقدة التي يعمل عليها التّابع مُغايرةً لعقدة المُستند، فالتّابع <code>Element.getElementsByTagNameNS()‎</code> يُستَخدمُ عوضًا عن هذا التّابع.
  
لاستخدام المثال التّالي، انسخه وألصقه في ملفٍّ جديدٍ بالامتداد <code>.xhtml‎</code>.
+
لاستخدام المثال التّالي، انسخه وألصقه في ملفٍّ جديدٍ بالامتداد <code>.xhtml‎‎</code>.
  
 
<syntaxhighlight lang="html">
 
<syntaxhighlight lang="html">
سطر 97: سطر 97:
  
 
==طريقة محتملة لدعم المتصفحات غير المدعومة==
 
==طريقة محتملة لدعم المتصفحات غير المدعومة==
إن لم يكن المتصفّح يدعم ميّزة XPath، فلا بد من استعمال طريقةٍ أخرى (مثل المرور عبر DOM عبر جميع أولاده، التّعرّف على جميع نُسخ ‎@‎xmlns ...) للبحث عن جميع الوسوم ذات الاسم المحلي ومجال الأسماء المرغوبين، لكنّ XPath أسرع بكثير.
+
إن لم يكن المتصفّح يدعم ميّزة XPath، فلا بد من استعمال طريقةٍ أخرى (مثل المرور عبر DOM عبر جميع أولاده، التّعرّف على جميع نُسخ ‎@‎xmlns، أو ما شابه ذلك) للبحث عن جميع الوسوم ذات الاسم المحلي ومجال الأسماء المرغوبين، لكنّ XPath أسرع بكثير.
 +
 
 
لدعم مُتصفّح Internet Explorer، يُمكن استدعاء XPath عبر غشاءٍ (wrapper) عوضًا عن استدعاء XPath مُباشرةً في المثال أدناه (وذلك لأنّ Internet Explorer يدعم XPath عبر واجهةٍ برمجيّة مُختلفة).
 
لدعم مُتصفّح Internet Explorer، يُمكن استدعاء XPath عبر غشاءٍ (wrapper) عوضًا عن استدعاء XPath مُباشرةً في المثال أدناه (وذلك لأنّ Internet Explorer يدعم XPath عبر واجهةٍ برمجيّة مُختلفة).
 
<syntaxhighlight lang="javascript">
 
<syntaxhighlight lang="javascript">

مراجعة 12:39، 27 مارس 2018

يُعيد التّابع Document.getElementsByTagNameNS()‎ قائمةً تحتوي على جميع العناصر ذات اسم الوسم (tag name) التّابع لمجال الأسماء (namespace) المعطيين. عند استدعائه على كائن المُستند، فسيُبحَثُ في كامل المُستند، ما يشمل العقدة الجذر.

البنية العامة

elements = document.getElementsByTagNameNS(namespace, name)

القيم

elements‎

كائنٌ حيّ من النّوع NodeList‎ (لكن انظر الملاحظة أدناه) يُمثّل مجموعة العناصِر التي وُجدت مرتّبةً حسب طريقة عرضها في شجرة DOM.

namespace‎

عنوان URI مجال الأسماء المبحوث عنه (انظر ‎element.namespaceURI).

name‎

سلسلةٌ نصيّةٌ تُمثّل أسماء العناصِر المبحوث عنها. السلسلة النّصيّة الخاصّة "*"‎ تُمثّل جميع العناصر (انظر ‎element.localName).

مُلاحظة: تقول مواصفة W3C بأنّ قيمة elements‎ عبارةٌ عن كائن NodeList‎، لكنّ هذا التّابع يُعيد كائنا من النّوع HTMLCollection‎ في مُتصفّح Internet Explorer وFirefox. يُعيد متصفّح Opera كائن NodeList‎ ذي تابعٍ namedItem مُطبَّق، ما يجعل الكائن مُشابها للكائن HTMLCollection‎. يُعيد هذا التّابع كائنا صحيحًا من النّوع NodeList فقط في مُتصفّحات WebKit (مثل Chrome وSafari). انظر العلّة 14869 للمزيد من التّفاصيل.

أمثلة

يبدأ التّابع Document.getElementsByTagName()‎ في المثال التّالي من عنصرٍ أبٍ معيّنٍ ويبحث من الأعلى إلى الأسفل تعاوديًّا (recursively) عبر DOM بدايةً من العنصر الأب، بانيًّا مجموعة عناصر أولاد يُساوي اسمها المُعامل name‎. لاحظ أنّه عندما تكون العقدة التي يعمل عليها التّابع مُغايرةً لعقدة المُستند، فالتّابع Element.getElementsByTagNameNS()‎ يُستَخدمُ عوضًا عن هذا التّابع.

لاستخدام المثال التّالي، انسخه وألصقه في ملفٍّ جديدٍ بالامتداد ‎.xhtml‎‎.

<html xmlns="http://www.w3.org/1999/xhtml">

<head>
<title>getElementsByTagNameNS example</title>

<script type="text/javascript">

function getAllParaElems()
{
  var allParas = document.getElementsByTagNameNS("http://www.w3.org/1999/xhtml", "p");

  var num = allParas.length;

  alert('هناك' + num + ' عناصر في هذا المستند');
}


function div1ParaElems()
{
  var div1 = document.getElementById("div1")
  var div1Paras = div1.getElementsByTagNameNS("http://www.w3.org/1999/xhtml", "p");

  var num = div1Paras.length;

  alert('هناك' + num + ' عناصر في  div1');
}


function div2ParaElems()
{
  var div2 = document.getElementById("div2")
  var div2Paras = div2.getElementsByTagNameNS("http://www.w3.org/1999/xhtml", "p");

  var num = div2Paras.length;

  alert('هناك' + num + ' عناصر في  div2');
}

</script>
</head>

<body style="border: solid green 3px">
  <p>نصّ خارجيّ</p>
  <p>نصّ خارجيّ</p>      

  <div id="div1" style="border: solid blue 3px">
    <p>نصّ div1</p>
    <p>نصّ  div1</p>
    <p>نصّ div1</p>     

    <div id="div2" style="border: solid red 3px">
      <p>نصّ div2</p>
      <p>نصّ div2</p>
    </div>
  </div>

  <p>نصّ خارجيّ</p>
  <p>نصّ خارجيّ</p>

  <button onclick="getAllParaElems();">
    أظهر جميع عناصر p في المستند</button><br />

  <button onclick="div1ParaElems();">
    أظهر جميع عناصر p في المستند في العنصر div1</button><br />

  <button onclick="div2ParaElems();">
    أظهر جميع عناصر p في المستند في العنصر div2</button>
</body>
</html>

طريقة محتملة لدعم المتصفحات غير المدعومة

إن لم يكن المتصفّح يدعم ميّزة XPath، فلا بد من استعمال طريقةٍ أخرى (مثل المرور عبر DOM عبر جميع أولاده، التّعرّف على جميع نُسخ ‎@‎xmlns، أو ما شابه ذلك) للبحث عن جميع الوسوم ذات الاسم المحلي ومجال الأسماء المرغوبين، لكنّ XPath أسرع بكثير.

لدعم مُتصفّح Internet Explorer، يُمكن استدعاء XPath عبر غشاءٍ (wrapper) عوضًا عن استدعاء XPath مُباشرةً في المثال أدناه (وذلك لأنّ Internet Explorer يدعم XPath عبر واجهةٍ برمجيّة مُختلفة).

function getElementsByTagNameNSWrapper (ns, elName, doc, context) {
	if (!doc) {
		doc = document;
	}
	if (!context) {
		context = doc;
	}

	var result = doc.evaluate('//*[local-name()="'+elName+'" and namespace-uri() = "'+ns+'"]', context, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);

        var a = [];
        for(var i = 0; i < result.snapshotLength; i++) {
            a[i] = result.snapshotItem(i);
        }
        return a;
}

مصادر ومواصفات