微信的内嵌浏览器使用的是 WebView,当查看分享时打开的页面就是使用 WebView 呈现的。手机淘宝客户端也在页面中使用了 WebView。淘宝页面这种经常变化很大,对动画和流程性没要求的话,会优先使用 WebView。所以 App 的原则是经常变用 WebView,不经常变就 Native。
可以通过下列方式判断 APP 使用的哪种技术。打开开发者模式———显示布局边界。若是整块区域有边界,则是 WebView。如果每个元素都有边界,则不是。
WebView 中请求页面在微信朋友圈中查看分享时,会调到这样一个页面。其实就是在这个框架中去请求数据
下面模拟这种方案。 - package timenull.friendcircle;
- import android.os.Bundle;
- import android.app.Activity;
- import android.view.KeyEvent;
- import android.webkit.WebView;
- public class MainActivity extends Activity {
- private WebView webview;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- webview = new WebView(this);
- webview.getSettings().setJavaScriptEnabled(true);
- webview.loadUrl("http://fuzhii.com");
- //设置Web视图
- setContentView(webview);
- }
- @Override
- //设置回退
- //覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法
- public boolean onKeyDown(int keyCode, KeyEvent event) {
- if ((keyCode == KeyEvent.KEYCODE_BACK) && webview.canGoBack()) {
- webview.goBack();
- return true;
- }
- return false;
- }
- }
复制代码分为下面几步 1.在 Activity 中实例化 WebView 组件 webview = new WebView(this);
2.调用 WebView 的 loadUrl() 方法,设置 WebView 要显示的网页。 webview.loadUrl("http://fuzhii.com");
3.调用 Activity 的 setContentView() 方法显示网页视图
4.另外需要在 AndroidManifest.xml 文件中添加访问网络的权限 <uses-permission android:name="android.permission.INTERNET"/>
最后效果如下
WebView 优点
|