استرداد مسار CSS من عنصر DOM بدقة محسنة
تحاول الوظيفة المقدمة إنشاء مسار CSS لعنصر DOM معين. ومع ذلك، فإن مخرجاته تفتقر إلى التحديد، حيث تفشل في التقاط موضع العنصر داخل أشقائه. لمعالجة هذه المشكلة، نحتاج إلى نهج أكثر تطورًا.
تحسين وظيفة مسار CSS
تعالج الوظيفة المحسنة المعروضة أدناه القيود الأصلية:
var cssPath = function(el) { if (!(el instanceof Element)) return; var path = []; while (el.nodeType === Node.ELEMENT_NODE) { var selector = el.nodeName.toLowerCase(); if (el.id) { selector = '#' el.id; path.unshift(selector); break; } else { var sib = el, nth = 1; while (sib = sib.previousElementSibling) { if (sib.nodeName.toLowerCase() == selector) nth ; } if (nth != 1) selector = ":nth-of-type(" nth ")"; } path.unshift(selector); el = el.parentNode; } return path.join(" > "); }
التحسينات والفوائد:
باستخدام هذه الوظيفة المحسنة، يمكن للمرء الآن الحصول على مسار CSS أكثر دقة لعنصر معين:
console.log(cssPath(document .getElementsByTagName('a')[123])); // الإخراج: "html > body > div#div-id > div.site:nth-child(1) > div.clearfix > ul.choices > li:nth-child(5)"
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3