此处将为大家介绍关于lua与javascript的相似之处的详细内容,并且为您解答有关lua和javascript的相关问题,此外,我们还将为您介绍关于actionscript与javascript的
此处将为大家介绍关于lua与javascript的相似之处的详细内容,并且为您解答有关lua和javascript的相关问题,此外,我们还将为您介绍关于actionscript与javascript的区别、actionscript与javascript的区别_基础知识、Android中Java与JavaScript之间交互、android中WebView的Java与JavaScript交互的有用信息。
本文目录一览:- lua与javascript的相似之处(lua和javascript)
- actionscript与javascript的区别
- actionscript与javascript的区别_基础知识
- Android中Java与JavaScript之间交互
- android中WebView的Java与JavaScript交互
lua与javascript的相似之处(lua和javascript)
1. lua中的table,类似于javascript中的Array(数组,同时也是Object,可以当Map用)
- address={1,2,3}
- address.Street="Wyman Street"
- address.Contry="USA"
- print(address.Street,address["Contry"]
2. 与javascript类似,所有的变量默认为全局变量.lua中的local与javascript中的var作用一样,使得变量成为局部变量
- -- All variables are global in scope by default.
- b="global"
- -- To make local variables you must put the keyword 'local' in front.
- function myfunc()
- local b=" local variable"
- a="global variable"
- print(a,b)
- end
- myfunc()
- print(a,b)
- -------- Output ------
- global variable local variable
- global variable global
3. and 和 or的运算结果不是true和false,而是操作数的结果,这一点跟javascript类似
4. Lua函数的参数传入方式与javascript类似,,多余的部分被省略,缺少部分用nil补足
5. 与javascript类似,lua是基于对象的,其可以用setMetatable()设置一个元表(Metatable),这个元表类似于javascript的prototype
6. 类似javascript,lua将函数看成一个变量
actionscript与javascript的区别
当时Netscape的JavaScript使其在与ie的浏览器大战中独占鳌头,而后ie创建了jscript应对Netscape的JavaScript,而事实上jscript基本上抄袭的JavaScript,这也是微软一直备受诟病的一件事,jscript与JavaScript有一些语法上的不一样,但二者均是同一类web开发技术,而且目前流行的是JavaScript,jscript的使用已经越来越少了。另外JavaScript的核心为ecmascript,与actionscript的核心一样,所以学会了JavaScript以后学习actionscript会比较容易,反之亦然。- JavaScript和ActionScript的交互实现代码
- Javascript 调用 ActionScript 的简单方法
- JavaScript与ActionScript3两者的同性与差异性
- Actionscript与javascript交互实例程序(修改)
actionscript与javascript的区别_基础知识
当时Netscape的JavaScript使其在与ie的浏览器大战中独占鳌头,而后ie创建了jscript应对Netscape的JavaScript,而事实上jscript基本上抄袭的JavaScript,这也是微软一直备受诟病的一件事,jscript与JavaScript有一些语法上的不一样,但二者均是同一类web开发技术,而且目前流行的是JavaScript,jscript的使用已经越来越少了。另外JavaScript的核心为ecmascript,与actionscript的核心一样,所以学会了JavaScript以后学习actionscript会比较容易,反之亦然。
Android中Java与JavaScript之间交互
Android代码:
package com.fyfeng.testjavascript;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.webkit.WebView;
import android.widget.Toast;
public class MainActivity extends ActionBarActivity {
private static final String tag = MainActivity.class.getSimpleName();
WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = (WebView) this.findViewById(R.id.webview);
webView.getSettings().setJavaScriptEnabled(true);//设置可以JavaScript
webView.loadUrl("http://192.168.1.104:8080/examples/");//加载网页
webView.addJavascriptInterface(new PayYa(), "pay");//定义一个支付结果,模拟。PayYa为支付接口处理类。
}
public void onClickPay() {
Intent intent = new Intent(this, SecondActivity.class);//模拟打开另外一个支付界面。
startActivityForResult(intent, 1000);
}
public void onPayCallback(String result) {
Log.d(tag, "result = " + result);
webView.loadUrl("javascript:payCallback(''" + result + "'');");//通知网页支付结果。
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {//支付结果返回
Log.d(tag, "requestCode = " + requestCode + ", resultCode = " + resultCode);
switch (requestCode) {
case 1000: {
if (Activity.RESULT_OK == resultCode) {
onPayCallback("hello, 这是支付结果. !");
}
break;
}
}
}
public final class PayYa {
@android.webkit.JavascriptInterface
public void pay(String hello) {//支付请求处理函数
Log.d(tag, "pay = " + hello);
onClickPay();
}
public void show(String args) {//这个函数是为了辅助显示网页中的alert对话框。
Toast.makeText(getApplicationContext(), args, Toast.LENGTH_SHORT).show();
}
}
}
网页部分代码:
<!DOCTYPE HTML><html lang="en"><head>
<meta charset="UTF-8">
<title>Apache Tomcat Examples</title>
<script type="text/javascript">
function doPay(args){
javascript:pay.pay(args+(new Date()));//调用Android本地支付接口函数,参数为args+new Date(); pay为在Android原生应用代码中定义的一个支付对象,这个支付对象有个pay(...)方法。
//javascript:pay.show("hello");
}
function payCallback(args){//Android本地支付处理完毕回调该函数,并把支付结果传递到该函数。
//alert("pay callback = "+args);
//打印支付结果。
javascript:pay.show(args); ////在Android的WebView中无法显示Alert对话框,只能借助Android原生Toast或者Dialog来显示。
}
</script>
</head>
<body>
<button onclick="doPay(''hello'')">doPay</button><!-- 点击支付事件。 -->
</body></html>
android中WebView的Java与JavaScript交互
android开发中经常使用WebView来加载网页,难免遇到Java与JavaScript的相互调用,记录下来,以便今后查阅。
Java调用JavaScript方法
这个很简单,只需一句代码:
webView.loadUrl("javascript:bb('这是Java调用JavaScript的结果')");
- 1
bb是html中的JavaScript的方法名,括号是参数。
JavaScript调用Java方法
在onCreate方法中,添加如下代码:
webView.addJavascriptInterface(this, "obj");
- 1
在该Activity中添加一个方法供JavaScript调用:
@JavascriptInterface
public String cc(){
return "这是Java代码返回的结果";
}
- 1
注意,`必须得有@JavascriptInterface注解加在方法的前面,否则,不起作用。
然后就可以在JavaScript中调用该Java方法了:
window.obj.cc()
- 1
该方法将会返回Java中cc()方法的返回值。
说明:webView.addJavascriptInterface()方法有两个参数,第一个参数是一个类实例,该类里面提供我们要提供给javascript访问的方法;第二个参数是访问我们在类中声明的方法时候所用到的js对象,调用模式为window.obj.方法名()。
下面给出全部的代码,便于大家动手操作:
index.html处于assets中:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<Meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>首页</title>
<script type="text/javascript" language="javascript">
function aa(){
alert(window.obj.cc())
}
function bb(text){
alert(text)
}
</script>
</head>
<body>
<button type="button" onclick="aa()">调用Java代码</button>
</body>
</html>
- 1
MainActivity.java就是主Activity文件了,大家都知道:
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.webkit.JavascriptInterface;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class MainActivity extends AppCompatActivity {
private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = (WebView)findViewById(R.id.webView);
WebSettings webSettings = webView.getSettings();
// 设置WebView属性,能够执行Javascript脚本
webSettings.setJavaScriptEnabled(true);
webView.setWebViewClient(new WebViewClient(){
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
webView.loadUrl("javascript:bb('这是Java调用JavaScript的结果')");
}
});
webView.setWebChromeClient(new WebChromeClient() {});
webView.loadUrl("file:///android_asset/index.html");
webView.addJavascriptInterface(this, "obj");
}
@JavascriptInterface
public String cc(){
return "这是Java代码返回的结果";
}
}
- 1
最后还有一个activity_main.xml布局文件也贴出来:
<?xml version="1.0" encoding="utf-8"?>
<WebView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:id="@+id/webView"
tools:context="com.example.webapplication.MainActivity">
</WebView>
- 1
关于lua与javascript的相似之处和lua和javascript的介绍已经告一段落,感谢您的耐心阅读,如果想了解更多关于actionscript与javascript的区别、actionscript与javascript的区别_基础知识、Android中Java与JavaScript之间交互、android中WebView的Java与JavaScript交互的相关信息,请在本站寻找。
本文标签: