General Tips
The list below is in not exhaustive but will somewhat set you in the right direction:
Design for mobile apps but implement the components using HTML and CSS only. JS must be the last resort!
Think of your mobile website as the interface of your mobile app in fullscreen mode.
Use intrinsic scaling to scale content (text, images, etc.). See intrinsic typography and utility variables.
Use flexbox or grids for layouts.
Default to PWA architecture. Enable strong page-level caching using a service-worker.
Optimize for the returning user instead of new user acquisition.
Use only a subset of your desktop workflow within you app workflow. Keep it simple.
The Point of Entry (POE) for your app and the point of entry of your web app are not the same. Use the
/login
page as the POE of your mobile app unless you know what you're doing.
Example:
POE → facebook.com ❌
POE → facebook.com/login ✅
Lose the footer at the bottom of your mobile website. See how Red Goose uses a semantic footer element with a full-page dedicated to footer links.
Go for an "app-like" interface on your webapp at every opportunity, especially on mobile views.
Simplicity is the ultimate sophistication. Use a simple slide-in or slide-out for menus. Less fancy is fast and better.
Split your webapp's functionality into levels and bring out only the most essential worflow into the fold of your app.
If possible, use
viewport
unitsvw, vh, vmax, vmin
to specify the UI elements of your app. Take a look at Toucaan CSS framework for app-like interface on mobile and tablets.Make sure that your web app is fast and performant. Checkout Lighthouse to understand performance-budgeting and test for speed.
Your website must be at least responsive. A non-responsive website cannot be converted into an "acceptable" mobile app.
Intrinsic design is recommended for "native-like" app experience. Refer the documentation of Toucaan CSS framework to implement intrinsic design on your app.
It is recommended to setup your development toolchain with a running Red Goose iOS or Android simulator. Point the url of your Red Goose app to
localhost
to develop for the mobile with hot reloading.
Read more about app development using Red Goose with the webstack.
It is always better (and economical) to use less code on the native side. Unless it is absolutely necessary, avoid adding native features to your Red Goose app. MAKE WEB DO YOUR BIDDING instead.
Resist the urge to add native functionality on your mobile app by keeping all your UX/UI related decisions on your web-app. That way you can control all the three mediums using one application.
Use native bundles in places where web functionality isn't available or not allowed by the owners of the app store i.e. Apple or Google.
There isn't much that the web cannot do today. ❤️
- Sometimes Apple or Google will reject your app for a seemingly ad-hoc reason. Look at the reasons provided by them for such a rejection, alleviate those issues (or appeal) and re-submit your app for approval. This is the normal process.
The Don'ts
No footer with links. An app screen will never carry a footer like a website does. Try and create a page for the collection of footer links and provide just one inconspicuous link to such a page (view).
No beta tag anywhere on the product or near the logo. All apps on the App Store must be final.
No third party or competitor branding (like an Android logo inside an iOS app) or names must be present on your app. Apple & Google are extremely sensitive about this.
No third party payments are allowed inside the App Store. Use in-app purchases for payment functionality on your app. Custom development may be required on case-to-case basis for this.
In general, it is safe to say that any web-app could be published like a mobile app no matter which line of business they are in. It is in the owner's interest to not overdo or overbuild native functionality in parallel to what exists on their web app already.
Always consider the web-based option first!