参考:
Framework7+Vue.js Spotify播放器 - 实例详解(1)
Framework7+Vue.js Spotify播放器 - 实例详解(2)
Framework7+Vue.js Spotify播放器 - 实例详解(3)
回顾一下:
- 用Template模板初始化
- 添加 Font Awesome Icon 图标库
- Framework7 View和Page概念
- 更新main视图
- 自定义样式文件CSS
- 初始化App应用,关联slider和显示的数值
- 调用Spotify API,处理返回数据
- 新的List页面(搜索结果)
- media页面(歌曲详情)
- 更多Mobile App元素:侧边栏Sidebar和元素左滑右滑Swipeout
11. 让你的App更有原生体验
从两个方面:外观、操作
-
外观CSS Tips
- 去除点击高亮:手机上,点击按钮本身就有反馈,不需要像网页一样高亮,所以去除
-webkit-tap-highlight-color: rgba(0,0,0,0);
-webkit-tap-highlight-color: transparent;
data:image/s3,"s3://crabby-images/59b72/59b729286628e2348c3f4f9187142af23a7ca2a2" alt=""
-
去除长按选择文字的功能:手机上一般不需要
Paste_Image.png
-webkit-user-select: none;
# for IE:
<meta name="msapplication-tap-highlight" content="no">
文本输入框还是需要的:Keep
-webkit-user-select: text;
for text input fields
-
去除控件光滑显示(iOS使用的是扁平化Flat设计)
Paste_Image.png
-webkit-appearance: none;
-
去除长按链接显示的菜单
Paste_Image.png
-webkit-touch-callout: none
- 使用原生滚动Native Scrolling,不显示滚动条,能感应滑动速度
-webkit-overflow-scrolling: touch;
- 使用手机系统字体System Fonts
iOS: font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
Android: font-family: 'RobotoRegular', 'Droid Sans', sans-serif;
Windows Phone: font-family: 'Segoe UI', Segoe, Tahoma, Geneva, sans-serif;
- 确保使用了FastClick,来处理手机tap delay
幸运的是,所有以上,Framework7默认都帮我们实现了!
你是在开玩笑么?NO!理解这些平台间差异,对于开发Hybrid App是非常重要的!
体验一下:
使用 Safari Developer tools (iOS device) 或Chrome Developer tools (Android device) ,远端调试remote debugging你的设备,然后手动修改一下Safari / Chrome里的CSS,体验一下,如果没有这些细节,体验会多么差!
- 操作性能
- 对于不同分辨率,提供不同尺寸的图片。使用SVG,会更好,因为它跟尺寸无关
- 对于长列表中的图片,使用懒加载Lazy load:
<img data-src="" width="64px" class="lazy">
,注意是data-src
。这样,不在当前视图里的图片,不会预先加载,只会显示width宽度的灰色方块。从而提升长列表加载的速度。
data:image/s3,"s3://crabby-images/c5ac6/c5ac6258def14629b72f0cba72ff9566e7922bfa" alt=""
- 动画使用GPU加速
.page-on-left {
opacity: .9;
-webkit-transform: translate3d(-20%, 0, 0);
transform: translate3d(-20%, 0, 0)
}
.page-on-center .swipeback-page-shadow {
opacity: 1
}
.page-on-right {
-webkit-transform: translate3d(100%, 0, 0);
transform: translate3d(100%, 0, 0)
}
Cordova的插件:Native Transitions Plugin,能很好地帮你加速过场。在过场动画时,它会先保存截屏,等待后台渲染好新页面时,再切换。
- HTML Caching缓存:尽可能先从内存里读页面
- iOS建议使用插件:super fast WKWebView -guide here
12. App参数调整
- Webview Bounce Effect / DisallowOverscroll
用phonegap开发的app,会存在ios下面整个页面能够被上下拖动的情况,这个只需要在config.xml中加入如下一行配置解决,整体拖不动(包括Navbar, Toolbar),但是页面还是可以上下拖动的
<preference name="DisallowOverscroll" value="true" />
- 关闭iOS Backup Storage (不然会存到iCloud)
<preference name="BackupWebStorage" value="none" />
以上,Framework7也默认帮你设置好了
- Content Security Policy
CSP用于保护你的App,免受cross-site scripting (XSS)的攻击。默认已安装插件Cordova Whitelist Plugin
# \spotifyApp\src\index.html
<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; script-src * 'unsafe-eval'; style-src 'self'; media-src *; frame-src *; img-src * data:; connect-src * 'unsafe-eval'">
# \spotifyApp\config.xml
<platform name="android">
<preference name="android-minSdkVersion" value="14" />
<allow-intent href="market:*" />
<allow-navigation href="http://*/*" />
</platform>
- 应用图标和Splash Screen
复制icon.png到/src/static/
文件夹,点这里下载。
# \spotifyApp\config.xml
<content src="index.html"/>
<icon src="www/static/icon.png" />
- Bonus:
Ionic有个实用的工具:Ionic Resources来自动生成各种尺寸的icon和Splash。你只要准备icon(192x192)、splash screen(2208x2208)就行。
查看这里post,来使用他们的工具。
Android可以使用Cordova Splash Screen plugin插件,在config.xml里定义SplashScreen:
# \spotifyApp\config.xml
<preference name="SplashScreen" value="screen"/>
<preference name="SplashScreenDelay" value="3000"/>
最终的config.xml,包含了各种尺寸的icon/SplashScreen,参考这里:
https://github.com/hollyschinsky/spotify-browser/blob/master/config.xml
列一下,目前为止,我们使用到的插件:
# \spotifyApp\config.xml
<plugin name="cordova-plugin-statusbar" spec="~1.0.1" />
<plugin name="cordova-plugin-console" spec="~1.0.1" />
<plugin name="cordova-plugin-whitelist" spec="~1.2.1" />
<plugin name="cordova-plugin-media" spec="~2.1.0" />
<plugin name="cordova-plugin-file" spec="~4.1.0" />
<plugin name="cordova-plugin-splashscreen" spec="~3.1.0" />
13. 添加原生分享功能
手机上分享,是非常常用的功能。对于某一歌曲,点击分享到。。。
data:image/s3,"s3://crabby-images/6f0eb/6f0eb3fd4bb5abfcc97a7d1bbcf2e0bb329822c5" alt=""
-
安装分享插件:
phonegap plugin add cordova-plugin-x-socialsharing --save
-
List页面,右滑的分享按钮,添加监听事件:
# \spotifyApp\src\assets\vue\List.vue
...
<f7-swipeout-button class="bg-blue">
<a href="#" class="bg-blue share" @click="share(index)"><i class="icon fa fa-share fa-2x"></i></a>
</f7-swipeout-button>
...
methods: {
share(index) {
var item = this.searchTracks[index];
if (window.plugins && window.plugins.socialsharing) {
window.plugins.socialsharing.share("Hey! My new favorite song is " + item.name + " check it out!",
'Check this out', item.album.images[2].url, item.preview_url,
function() {
console.log("Share Success")
},
function(error) {
console.log("Share fail " + error)
});
} else window.f7.alert("Share plugin not found");
}
}
- Media页面,右下角,分享按钮,添加监听事件:
跟List稍有不同,是通过this.mediaId
取得索引
# \spotifyApp\src\assets\vue\Media.vue
...
<f7-list-item class="bottom">
<a class="share item-media link" @click="share"><i class="icon fa fa-external-link fa-2x"></i></a>
</f7-list-item>
...
methods: {
share(index) {
var item = this.searchTracks[this.mediaId];
if (window.plugins && window.plugins.socialsharing) {
window.plugins.socialsharing.share("Hey! My new favorite song is " + item.name + " check it out!",
'Check this out', item.album.images[2].url, item.preview_url,
function() {
console.log("Share Success")
},
function(error) {
console.log("Share fail " + error)
});
} else window.f7.alert("Share plugin not found");
}
}
测试了一下,对于Facebook、Twitter、邮件等支持很好,但不支持微信
14. 处理网络Offline
对于手机应用来讲,网络通断是经常发生的。
如果能够提醒用户网络断了的话,对提升用户友好度有很大帮助
data:image/s3,"s3://crabby-images/64b98/64b98c7c35da9c7601a35bf9b5e85efe67b6a4d8" alt=""
安装:
phonegap plugin add cordova-plugin-network-information --save
使用:
- 在
mounted: {}
里添加事件监听
# /src/main.vue
mounted() {
document.addEventListener("offline", this.onOnlineOffline, false);
document.addEventListener("online", this.onOnlineOffline, false);
}
- 在
methods: {}
里添加处理事件
# /src/main.vue
methods: {
onOnlineOffline () {
if (navigator.connection && navigator.connection.type == Connection.NONE) {
// offline, set a flag to grey
this.offline = true;
windows.alert("network connection lost!");
}
else {
// It's connected, set a flag and icon colors
this.offline = false;
}
}
15. 调试App
在真机上调试App,必须要有顺手的工具,不然出了问题无从下手。
你可以从以下工具中选择:
- iOS Remote Debugging via Safari
Requirements - Mac OS X
- USB Cable
- Safari Version 6.0+
- iOS Device or Simulator
data:image/s3,"s3://crabby-images/a8a33/a8a332eb9a43b536db08d0c981d294ef6a6cfd1b" alt=""
- Android Device Debugging via Chrome
Requirements - USB Cable
- Chrome Version 32+
- Android Device or Emulator (已打开USB调试功能)
- Android Studio or Android Tools (打包Apk时才会用到)
data:image/s3,"s3://crabby-images/e71b7/e71b7fee09424dbb07c0dd5489ff504922036b65" alt=""
结语
现在,你已经完成一个简单的App,并走完了整个开发流程。
最终代码:https://github.com/kevinqqnj/spotifyApp
下面,开发你自己的实用App吧!
另外,你也可以参考这些:
Next Steps
-
测试和性能评估(Testing, Profiling)
browser-perf- a node based tool
Remote Debugging on Android
Debugging with Safari Web Inspector -
安全(Securing your App)
Tommy Williams PhoneGap Day 2016 Workshop -
统计(Analytics)
你的App是怎么被使用的,哪些功能用得最多,哪些是痛点
Adding Analytics to your PhoneGap Apps
useful guide to App Submission -
更新(Updating your App)
Code Push Plugin (using MS CodePush Service)
Hot Code Cordova Push Pluginandassociated CLI
Learn how exFM did it(read the section titledLoading Assets).
Ionic Deployservice -
A/B Testing
Optimizely Cordova Plugin
Leanplum Cordova Plugin -
推送服务(Push Notification)
Simon’s MacDonald’s PhoneGap Day Push Notification Workshop -
插件开发(Plugin)
Jesse MacFadyen’s PhoneGap Day 2016 Slides -
Developer Guides
Managing Click Delay
Plugin Architecture
Single Page Architecture -
性能(Performance Tips)
Using CSS Sprite Sheets
Hardware Acceleration
Paint Before Animate
Scrolling Tips
Minimize Reflows
Serve Images at Resolution
参考:
PhoneGap Hybrid APP 开发实战(2):Framework7 + Vue.js模板
Phonegap踩过的坑 | IT瘾
PhoneGap Day EU Workshop
网友评论