In the context of mobile apps, deep linking consists of using a uniform resource identifier (URI) that links to a specific location within a mobile app rather than simply launching the app. Deferred deep linking allows users to deep link to content even if the app is not already installed. Depending on the mobile device platform, the URI required to trigger the app may be different.
Unlike the Web, where the underlying technology of HTTP and URLs allows for deep linking by default, enabling deep linking on mobile apps requires these apps be configured to properly handle a uniform resource identifier (URI). Examples of URIs that launch a mobile app:
twitter://
is the iOS URI to launch Twitter's mobile appYouTube://
is the iOS URI to launch YouTube's mobile appThe format of the URI used to trigger or deep link an app is often different depending on the mobile operating system. Android devices work through intents,[1] BlackBerry 10 devices work through BB10's invocation framework,[2] Firefox OS devices work through Web Activities,[3] iOS devices work through the open(_:options:completionHandler:) application method,[4] and Windows Phone 8 devices work through the UriMapper class.[5]
fb://profile/33138223345
is an example of a mobile deep link URI. The URI contains all the information needed to launch directly into a particular location within an app, in this case the profile with id '33138223345
', i.e., the Wikipedia page, within the Facebook app, instead of simply the info for launching the Facebook app fb://
.eBay://launch?itm=360703170135
is the URI of a deep link into eBay's iOS app while eBay://item/view?id=360703170135
is the URI of a deep link into eBay's Android app.The greatest benefit of mobile deep linking is the ability for marketers and app developers to bring users directly to a specific location within their app with a dedicated link. Just as deep links make the web more usable,[6] mobile deep links do the same for mobile apps.[7]
Unlike deep links on the web, where the link format is standardized based on HTTP guidelines, mobile deep links do not follow a consistent format. This causes confusion in development because different sets of links are required to access the same app on a different mobile operating system.
Google allows app developers who have both iOS and Android apps to surface in-app content via mobile Google searches. Developers will need to submit their apps and deep linking apps on both iOS and Android to be indexed by Google.[8] Alternatively, developers can use Google's short links to deep link mobile app users if the app is installed and direct others to the webpage.[9]
One example of a better user experience made possible because of the deep link and data passing through the install solution is one in which search information is passed into an app to bring the user to the exact information that drove them to the app. Compared to a common web link, this implementation may reduce the number of steps required. For example, to search for hotels in Boston, a user currently needs to:[10]
That can be shortened to:
Deferred deep linking is one aspect of mobile deep linking. It describes the principle of deep linking into an app that is not yet installed. In this case, deep linking will be "deferred" until the application is installed by the user. This implies that clicking (or otherwise invoking) the deep link causes:
A common use case is to drive installs; linking to functionality in a not-yet-installed app provides the user with an incentive to install it.
Deferred deep linking allows mobile developers and mobile marketers to deliver a seamless and automated user experience, whether the app was previously installed or not, improving conversion rates and user retention.
While there is currently no industry standard for deferred deep linking, various platform providers offer differing levels of support: