To answer this question, let’s go over how the mobile view is created by SharePoint. It is quite similar to 2007, but a few enhancements do help with the experience.
When user try to browse SharePoint 2010 site from his/her phone, the mobile browser submits a HTTP GET request to the website. In this request, a User Agent string is attached so the website can identify the browser and even the phone model. SharePoint analyzes this UA string, if it is a phone or mobile device, SharePoint will redirect the browser automatically to the mobile view and render the view based on the capability of the browser/phone type. A browser definition file is needed in this process to let SharePoint know what this browser can do.
Take one of my SharePoint 2010 farm as an example.
The browser definition file of a SharePoint Web Application which listening port 80 by default locates at
C:\inetpub\wwwroot\wss\VirtualDirectories\80\App_Browsers\compat.browser
In this file, you can find a very big list of different browsers and phone models. The schema of this file can be found in .Net Framework reference: Browser Definition File Schema (browsers Element)
Sample phone is AT&T HTC Fuze, it is also called HTC Touch Pro, or T7272. IE6 Mobile is the default browser. Here’s the section for it:
<!-- IE Mobile 6 plus browser -->
<!-- note: some IE Mobile 6 devices call itself as IEMobile 7+ -->
<!-- sample UA "HTC_Touch_Pro_T7272 Mozilla/4.0 (compatible; MSIE 6.0; Windows CE; IEMobile 7.11)" -->
<!-- sample UA "SAMSUNG-SGH-i908/1.0 Release/03.07 Browser/IE6 Profile/MIDP-2.0 Configuration/CLDC-1.1 (compatible; MSIE 6.0;
Windows CE; IEMobile 7.11)" -->
<browser id="IEMobile6Plus" parentID="Mozilla">
<identification>
<userAgent match="Windows CE" />
<userAgent match="IEMobile (?'version'((?'major'([6-9])+)(?'minor'\.\d*)))" />
</identification>
<capabilities>
<capability name="browser" value="IE Mobile" />
<capability name="canInitiateVoiceCall" value="true" />
<capability name="isMobileDevice" value="true" />
<capability name="javascript" value="true" />
<capability name="optimumPageWeight" value="1500" />
<capability name="tables" value="true" />
<capability name="version" value="${version}" />
</capabilities>
</browser>
As a SharePoint Administrator, you can add more browsers definitions into the file. These definitions can also be updated by SharePoint updates.
Here’s the render difference example between a decent big touch screen phone and a Nokia 3120 (a 6 years old typical non-touch screen S40 phone). Please note this is not a real one – I changed my browser’s user agent to let SharePoint believe it’s a Nokia 3120.
(Left – modern touch screen mobile browser experience; Right – Nokia 3120 )
Home page – despite the styles difference, the text content on the page is not displayed directly on 3120. It can be accessed through button 1 – Show text only.
data:image/s3,"s3://crabby-images/ba025/ba02547b84564b29e1d9e7be22c3cf51e09fa116" alt="snap0076 snap0076"
data:image/s3,"s3://crabby-images/e9284/e92844f0865259ec6ac83901bac0055513f8c497" alt="snap0072 snap0072"
Excel Mobile Viewer commands – it shows more rows and columns to fit into the modern phone screen.
data:image/s3,"s3://crabby-images/d1a26/d1a267254bf1c221e8ef7bdbdb5647319f2df950" alt="snap0074 snap0074"
data:image/s3,"s3://crabby-images/119aa/119aa9a43ed6d6b2d7de7dc26f42624244cf80d4" alt="snap0075 snap0075"
Don’t forget to check out Mobile administration section on TechNet!