在dom scrape中寻找子元素的选择器

时间:2015-08-02 14:40:29

标签: javascript selector

我无法更改相关网站上的任何HTML。

这是一些html:

<ul id="utility-menu" class="menu menu--primary">

        <li><a class="" href="https://www.example.com/newsstand" target="_blank">Magazines</a></li>

        <li><a class="" href="https://secure.bla.com/example/promo/GiveAGift/" target="_blank">Gifts</a></li>

        <li>

          <a href="/email_check?lang=fr">Français</a>
        </li>

            <li><a class="" href="/signin">Sign In</a></li>

        <li>
          <div class="i-am-canadian">
            <img alt="Canadian flag" height="23px;" src="https://secure.example.com/assets/images/icons/ui/i-canadian-c8a132ad64588dcc0b2e61cc589dfef3.png" width="40px;">
          </div>
        </li>
      </ul>

我设法使用以下方式选择菜单:

document.querySelectorAll('.menu--primary')[0]

我感兴趣的元素是:

<a href="/email_check?lang=fr">Français</a>

此元素是网站访问者的语言选择,将是“英语”或“Français”。

如果用户在英语语言页面上,则元素的值将显示为该值。但如果它们与法语等价,则元素将为<a href="/email_check?lang=en">English</a>

我想要一个返回“English”或“Français”的选择器。

我该怎么做?

2 个答案:

答案 0 :(得分:2)

答案:

var el = document.querySelector('#utility-menu a[href^="/email_check?lang="').textContent;

它会在a中选择href元素,其中/email_check?lang=元素以#utility-menu开头。可能你可以.trim()发送文字以消除空白。

答案 1 :(得分:1)

如果你的html不会有太大变化,你可以使用

var test = document.querySelector("ul > li > a[href='/email_check?lang=fr']");

console.log(test.textContent); // Français

https://jsfiddle.net/u4vjq8ah/