加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

Android与JavaScript技巧相互调用

发布时间:2021-11-25 18:19:04 所属栏目:PHP教程 来源:互联网
导读:在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavascriptInterface方法,这样html才能调用android方法,在这里我个人觉得有点和DWR相似。 为了让大家容易理解,我写了一个简单的Demo,具体步骤如下: 第一

在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavascriptInterface方法,这样html才能调用android方法,在这里我个人觉得有点和DWR相似。
 
为了让大家容易理解,我写了一个简单的Demo,具体步骤如下:
 
第一步:新建一个Android工程,命名为WebViewDemo(这里我在assets里定义了一个html页面)。
 
 
 
第二步:修改main.xml布局文件,增加了一个WebView控件还有Button控件,代码如下:
 
<?xml version="1.0" encoding="utf-8"?>     
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    android:orientation="vertical"   
    android:layout_width="fill_parent"   
    android:layout_height="fill_parent"   
    >     
    <TextView       
        android:layout_width="fill_parent"      
        android:layout_height="wrap_content"      
        android:text="Welcome to Mr Wei's Blog."   
        />     
    <WebView     
        android:id="@+id/webview"   
        android:layout_width="fill_parent"      
        android:layout_height="wrap_content"      
    />     
    <Button     
        android:id="@+id/button"   
        android:layout_width="fill_parent"   
        android:layout_height="wrap_content"   
        android:text="Change the webview content"   
    />     
</LinearLayout>   
<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >  
<TextView   
     android:layout_width="fill_parent"   
     android:layout_height="wrap_content"   
     android:text="Welcome to Mr Wei's Blog."  
     />  
<WebView  
   android:id="@+id/webview"  
   android:layout_width="fill_parent"   
     android:layout_height="wrap_content"   
/>  
<Button  
   android:id="@+id/button"  
   android:layout_width="fill_parent"  
   android:layout_height="wrap_content"  
   android:text="Change the webview content"  
/>  
</LinearLayout>  
第三步:在assets目录下新建一个demo.html文件,代码如下(这里不知道为何多了mce:这几个东东,<script></script>这样是对的):
 
<html>     
    <mce:script language="javascript"><!--     
      
        function fillContent(){     
            document.getElementById("content").innerHTML =      
                 "This Content is showed by Android invoke Javascript function.";     
        }     
         
// --></mce:script>        
<body>     
    <p><a onClick="window.demo.startMap()" href="">Start GoogleMap</a></p>     
    <p id="content"></p>     
    <p>A Demo ----Android and Javascript invoke each other.</p>     
    <p>Author:Frankiewei</p>     
</body>     
</html>     
<html>  
<mce:script language="javascript"><!--  
  
   function fillContent(){  
    document.getElementById("content").innerHTML =   
        "This Content is showed by Android invoke Javascript function.";  
   }  
  
// --></mce:script>    
<body>  
<p><a onClick="window.demo.startMap()" href="">Start GoogleMap</a></p>  
<p id="content"></p>  
<p>A Demo ----Android and Javascript invoke each other.</p>  
<p>Author:Frankiewei</p>  
</body>  
</html>  

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读