I'm using Google+ quite heavily and one thing I find myself doing extremely frequently is clicking the 'More' button in the left-hand sidebar to access my circles that are hidden from view. I'm trying to write a user script that will activate the "More" link for me on page load. This is the DOM structure of the sidebar upto the "More" element:
<div class="a-b-la-A">
<h2 class="a-za">Navigation</h2>
<a href="/welcome" target="_top" class="d-h a-b-h-Jb a-la-h a-la-aH ">Welcome</a>
<div class="a-la-Dd"></div>
<a href="/stream" target="_top" class="d-h a-b-h-Jb a-la-h a-la-aH a-la-h-Pa">Stream</a>
<div class="a-la-h-ga"><a href="/stream/circles/p5653c3hhy60aadf997" target="_top" class="d-h a-b-h-Jb a-la-h a-la-Rb-h a-b-la-Rb-h">Friends</a></div>
<span role="button" class="d-h a-b-la-gc-h a-la-h a-la-hA" tabindex="0">More<span class="a-b-la-bw a-la-tb-q">▾</span></span>
开发者_如何学C...and here's the snippet I'm working on:
$('div.a-b-la-A span').filter('[role="button"]:contains("More")').trigger('click');
I can select and manipulate the 'More' element just fine and here's the bg-color set to yellow with:
$('div.a-b-la-A span').filter('[role="button"]:contains("More")').css({'background-color': 'yellow'});
...but I still can't activate the function tied to the element. Things I've tried:
- tried using .click() instead of trigger('click')
- tried to identify the function getting triggered on click, using Firebug and Event Spy with no success
- tried .mousedown() and trigger('mousedown') instead of triggering the 'click' event
Any other ideas?
Use low-level code to Fire the JS link. Something like this should work:
var clickEvent = document.createEvent ("HTMLEvents");
clickEvent.initEvent ("click", true, true);
var jNode = $('div.a-b-la-A span').filter('[role="button"]:contains("More")');
if (jNode.length != 1)
alert ('Oops! Found too many (or no) "More" links');
jNode[0].dispatchEvent (clickEvent);
精彩评论