微信的内嵌浏览器使用的是 WebView,当查看分享时打开的页面就是使用 WebView 呈现的。手机淘宝客户端也在页面中使用了 WebView。淘宝页面这种常常变化很大,对动画和流程性没要求的话,会优先使用 WebView。因此 App 的原则是常常变用 WebView,不常常变就 Native。前端
能够经过下列方式判断 APP 使用的哪一种技术。打开开发者模式———显示布局边界。如果整块区域有边界,则是 WebView。若是每一个元素都有边界,则不是。android
在微信朋友圈中查看分享时,会调到这样一个页面。其实就是在这个框架中去请求数据。web
下面模拟这种方案。浏览器
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);
app
2.调用 WebView 的 loadUrl() 方法,设置 WebView 要显示的网页。框架
webview.loadUrl("http://fuzhii.com");
ide
3.调用 Activity 的 setContentView() 方法显示网页视图布局
4.另外须要在 AndroidManifest.xml 文件中添加访问网络的权限
<uses-permission android:name="android.permission.INTERNET"/>
最后效果以下