Last modified: 2014-02-12 23:45:40 UTC

Wikimedia Bugzilla is closed!

Wikimedia migrated from Bugzilla to Phabricator. Bug reports are handled in Wikimedia Phabricator.
This static website is read-only and for historical purposes. It is not possible to log in and except for displaying bug reports and their history, links might be broken. See T33011, the corresponding Phabricator task for complete and up-to-date bug report information.
Bug 31011 - MobileFrontend should load sections dynamically as much as possible to avoid downloading never-viewed text and images
MobileFrontend should load sections dynamically as much as possible to avoid ...
Status: RESOLVED FIXED
Product: MobileFrontend
Classification: Unclassified
Feature requests (Other open bugs)
unspecified
All All
: Normal enhancement
: ---
Assigned To: Nobody - You can work on this!
http://en.wikipedia.org/wiki/Obama?us...
:
: 33266 (view as bug list)
Depends on:
Blocks:
  Show dependency treegraph
 
Reported: 2011-09-19 20:58 UTC by Brion Vibber
Modified: 2014-02-12 23:45 UTC (History)
11 users (show)

See Also:
Web browser: ---
Mobile Platform: ---
Assignee Huggle Beta Tester: ---


Attachments

Description Brion Vibber 2011-09-19 20:58:33 UTC
At least on the views given to regular web browsers and a web browser masquerading as an iPhone, the text of pre-folded/hidden sections seems to still all be transferred with the rest of the page.

For instance the 'Obama' page transfers a whopping 720 KB of HTML (thankfully compressed down to 128 KB) although all that's shown is an infobox, four paragraphs, and a few section titles.

At least on the desktop version of Safari with tweaked User-Agent for iPhone, a large number of thumbnail images were also loaded despite being in hidden sections.
Comment 1 Mark A. Hershberger 2011-09-20 21:16:22 UTC
lowering priority till we have some actual field reports complaining about size or speed.
Comment 2 Brion Vibber 2011-09-20 23:31:04 UTC
I do recall a few anecdotes of people preferring the old en.mobile.wikipedia.org over en.m.wikipedia.org because the (very short) pages loaded so much faster.

I recommend doing a few test comparisons between long-form and cut-down versions of some articles on real 2g/3g data connections (not wifi!) to establish what the difference looks like in practice.
Comment 3 Krinkle 2011-09-20 23:38:10 UTC
I guess the css-hide is done with javascript on-load, after the browser has already parsed a bit of HTML and started downloading the <img>'s it has encountered so far.

A possible solution would be to (as far as this isn't the way it is already) wrap sections in <div>'s server side, give them a class, and in plain css (not javascript dependent) hide them with "html.js .section { display: none; }" and in the <head> add that class to the document.

That way they're hidden before parsed and still readable without JS. Testing that locally in a plain HTML file showed a significant difference in number of images being downloaded. (ie. none of the in section were downloaded on or after load until I expanded it)
Comment 4 Brion Vibber 2011-12-20 22:30:51 UTC
*** Bug 33266 has been marked as a duplicate of this bug. ***
Comment 5 Jon 2012-03-06 16:36:20 UTC
Images will be loaded as encountered in the html regardless of whether they are hidden by css.

To avoid this clicking toggle section would need to request the section from the server via an ajax call to the api and render on the callback rather than just adding a class to the document as it currently does.

An alternative would be for the api to set data-src on any images encountered and remove the src attribute and for javascript to set src attribute to data-src on the images on a toggle.
Comment 6 Max Semenik 2012-03-06 19:06:19 UTC
The only real way to drastically decrease traffic would be to load sections dynamically from API. The problem with it is that either people have JS, and JS support is sufficient for our needs, or they will not be able to view pages. Same thing with Jon's proposal - images will be invisible unless JS is supported. Make it opt-in only?
Comment 7 Jon 2012-03-07 14:57:54 UTC
Not necessarily. The first page could load as per normal and javascript could be used for future page loads that are done via search. This way the site works for everyone but users of javascript can get a faster mobile experience.
Comment 8 Max Semenik 2012-03-07 15:01:59 UTC
Nice idea, but how do you propose to pass the information about working JS? URL parameter - extra PITA to purge in squids. Cookie - user may disable JS later, even during the same session.
Comment 9 Jon 2012-03-07 15:08:42 UTC
Say I open http://en.m.wikipedia.org/wiki/San Francisco without javascript - I can use the search in that I type a search term and click okay and get a list of search results.

If I do have javascript however, javascript could override all the links in the page and the search in the page so that when a future page is loaded it is loaded via javascript.

Say there was a link to California in the San Francisco page. When I click California normally the following happens...

* request made to the api to get content
* content put into page via javascript
* functionality like toggling is added
* the address bar is updated to point to the new resource (http://en.m.wikipedia.org/wiki/California) [1]

Now the key thing is the page hasn't actually changed - I still have the same javascript and same html. If I hit refresh I load the full page as reflected in the address bar.

Note if I open California in a new window I get a full page load.

So essentially we'd be cutting down quite a few HTTP request and give a quicker experience to many users but not everyone.

[1] https://developer.mozilla.org/en/DOM/Manipulating_the_browser_history
Comment 10 Jon 2012-03-07 15:09:20 UTC
http://github.com is a great working example of this
Comment 11 Max Semenik 2012-03-07 15:12:39 UTC
Agreed.
Comment 12 Yair Rand 2012-03-07 22:18:59 UTC
(Duplicating what I posted on the duplicate bug.) Since this would also need to work for when a user clicks on a link to an anchor, this would require an API module that could be given an ID of an element, and return the ID of the surrounding section along with the complete contents of the section.
Comment 13 Max Semenik 2012-03-07 22:32:44 UTC
(In reply to comment #12)
> (Duplicating what I posted on the duplicate bug.) Since this would also need to
> work for when a user clicks on a link to an anchor, this would require an API
> module that could be given an ID of an element, and return the ID of the
> surrounding section along with the complete contents of the section.

If the user will click on link to section's anchor, they will jump to the collapsed section. This doesn't cover just a few cases when there's a custom anchor somewhere in the section - parser doesn't seem to provide this information.
Comment 15 Yuvi Panda 2012-06-24 14:17:08 UTC
Bug #37095 is equivalent on the app. I've implemented this in the app, awaiting review by Jon.
Comment 16 Yuvi Panda 2012-06-24 14:21:41 UTC
And I'll note that images are loaded in the app only when their section is expanded. This is because we load the html for the section into the DOM only when it is first expanded.
Comment 17 Jon 2012-10-26 21:43:29 UTC
This is currently deployed in beta mode
It currently has no fallback for older browsers
Comment 18 Arthur Richards 2012-12-14 21:34:27 UTC
Marking this resolved as support is now in beta.

Note You need to log in before you can comment on or make changes to this bug.


Navigation
Links