Heim Web-Frontend js-Tutorial js-Methode zum Empfangen und Konvertieren von Array-Objekten in Java

js-Methode zum Empfangen und Konvertieren von Array-Objekten in Java

Jan 14, 2017 am 10:45 AM

Wenn Sie bei der Arbeit an einem Projekt Befehle an die OCX-Steuerung erteilen möchten, müssen Sie das Objekt in Java in JS abrufen, es dann in ein Format bringen und versenden. . . Es ist einfach, wenn es sich bei dem Objekt um eins handelt, aber etwas schwieriger ist es, wenn das Objekt ein Array ist.

Zuerst dachte ich, es gäbe eine einfache Möglichkeit, den Inhalt direkt zu konvertieren, aber später fand ich heraus, dass es nicht möglich ist. Im Internet hieß es, dass es keine Brücke zwischen js und Java gibt, also:

Meine Lösung ist: Konvertieren Sie in der Aktionsebene das Java-Objekt-Array in einen JSON-String und in JS das JSON in ein Array-Objekt.

1. Konvertieren Sie das Java-Objekt-Array in einen Json-String:

Es werden zwei Klassen benötigt:

net.sf.json.JSONObject
net.sf.json.JSONArray
 
 
//将每个vehicle对象拼接为json格式的对象,用于命令下发
JSONObject json = JSONObject.fromObject(v); //v即对象
jsonArray.add(json);
//System.out.println(jsonArray.toString());
//用于命令下发
sendCommandList = jsonArray.toString();
Nach dem Login kopieren

Fügen Sie es in die for-Schleife ein.

2.js wandelt es in ein Objektarray um:

//注意:此时得到的是Json串。
 
//注意:要加上escapeJavaScript="false" escape="false" ,否则传过来Json字符串中的引号都会被解析成为"
 
var szJsonStr = &#39;<s:property escapeJavaScript="false" escape="false" value="sendCommandList" />&#39;;
Nach dem Login kopieren

Endlich:

//把Json字符串转化为对象数组
var addVehicleArray = eval(szJsonStr);
Nach dem Login kopieren

Wenn Sie es verwenden, verwenden Sie einfach addVehicleArray[i].vehicleType;. . . . . .

Erweiterungen:

Verwendung von JSONObject und JSONArray

1. Einführung in das JAR-Paket

Damit das Programm ausgeführt werden kann, muss das JSON-lib-Paket vorhanden sein eingeführt, JSON- Das lib-Paket hängt auch von den folgenden JAR-Paketen ab:

commons-lang.jar
commons-beanutils.jar
commons-collections.jar
commons- logging.jar
ezmorph.jar
json-lib-2.2.2-jdk15.jar

2. JSONObject-Objektverwendung

Das JSON-lib-Paket ist eine Reihe von Beans , Sammlungen, Karten, Java-Arrays und ein Paket zum Konvertieren von XML und JSON ineinander und voneinander. In diesem Beispiel erstellen wir JSONObject-Objekte mithilfe der JSONObject-Klasse und drucken dann die Werte dieser Objekte aus. Um JSONObject-Objekte verwenden zu können, müssen wir das Paket „net.sf.json“ einführen. Um Elemente zu einem Objekt hinzuzufügen, verwenden wir die Methode put().

2.1. Beispiel 1

package jsontest;
 
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
 
 
public class JSONObjectSample {
 
 
  // 创建JSONObject对象
  private static JSONObject createJSONObject() {
    JSONObject jsonObject = new JSONObject();
    jsonObject.put("username", "huangwuyi");
    jsonObject.put("sex", "男");
    jsonObject.put("QQ", "413425430");
    jsonObject.put("Min.score", new Integer(99));
    jsonObject.put("nickname", "梦中心境");
    return jsonObject;
  }
 
 
  public static void main(String[] args) {
    JSONObject jsonObject = JSONObjectSample.createJSONObject();//静待方法,直接通过类名+方法调用
    // 输出jsonobject对象
    System.out.println("jsonObject:" + jsonObject);
 
 
    // 判读输出对象的类型
    boolean isArray = jsonObject.isArray();
    boolean isEmpty = jsonObject.isEmpty();
    boolean isNullObject = jsonObject.isNullObject();
    System.out.println("是否为数组:" + isArray + ", 是否为空:" + isEmpty
        + ", isNullObject:" + isNullObject);
 
 
    // 添加属性,在jsonObject后面追加元素。
    jsonObject.element("address", "福建省厦门市");
    System.out.println("添加属性后的对象:" + jsonObject);
 
 
    // 返回一个JSONArray对象
    JSONArray jsonArray = new JSONArray();
    jsonArray.add(0, "this is a jsonArray value");
    jsonArray.add(1, "another jsonArray value");
    jsonObject.element("jsonArray", jsonArray);
    //在jsonObject后面住家一个jsonArray
    JSONArray array = jsonObject.getJSONArray("jsonArray");
    System.out.println(jsonObject);
     
     
    System.out.println("返回一个JSONArray对象:" + array);
    // 添加JSONArray后的值
    // {"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市","jsonArray":["this is a jsonArray value","another jsonArray value"]}
    System.out.println("结果=" + jsonObject);
 
 
    // 根据key返回一个字符串
    String username = jsonObject.getString("username");
    System.out.println("username==>" + username);
 
 
    // 把字符转换为 JSONObject
    String temp = jsonObject.toString();
    JSONObject object = JSONObject.fromObject(temp);
    // 转换后根据Key返回值
    System.out.println("qq=" + object.get("QQ"));
 
 
  }
 
 
}
Nach dem Login kopieren

Ausgabeergebnis

jsonObject:{"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境"}
是否为数组:false, 是否为空:false, isNullObject:false
添加属性后的对象:{"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市"}
{"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市","jsonArray":["this is a jsonArray value","another jsonArray value"]}
返回一个JSONArray对象:["this is a jsonArray value","another jsonArray value"]
结果={"username":"huangwuyi","sex":"男","QQ":"413425430","Min.score":99,"nickname":"梦中心境","address":"福建省厦门市","jsonArray":["this is a jsonArray value","another jsonArray value"]}
username==>huangwuyi
qq=413425430
Nach dem Login kopieren

2.2. Beispiel 2.

package jsontest;
 
 
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
 
 
public class JSONTest {
  public static void main(String args[])
  {
    JSONObject jsonObj0 = new JSONObject();
    JSONObject jsonObj = new JSONObject();
    JSONObject jsonObj2 = new JSONObject();
    JSONObject jsonObj3 = new JSONObject();
    JSONArray jsonArray = new JSONArray();
     
    //创建jsonObj0
    jsonObj0.put("name0", "zhangsan");
    jsonObj0.put("sex1", "female");
    System.out.println("jsonObj0:"+jsonObj0);
     
    //创建jsonObj1
    jsonObj.put("name", "xuwei");
    jsonObj.put("sex", "male");
    System.out.println("jsonObj:"+jsonObj);
   
    //创建jsonObj2,包含两个条目,条目内容分别为jsonObj0,jsonObj1
    jsonObj2.put("item0", jsonObj0);
    jsonObj2.put("item1", jsonObj);
    System.out.println("jsonObj2:"+jsonObj2);
     
    //创建jsonObj3,只有一个条目,内容为jsonObj2
    jsonObj3.element("j3", jsonObj2);
    System.out.println("jsonObj3:"+jsonObj3);
   
    //往JSONArray中添加JSONObject对象。发现JSONArray跟JSONObject的区别就是JSONArray比JSONObject多中括号[]
    jsonArray.add(jsonObj);
    System.out.println("jsonArray:"+jsonArray);
     
    JSONObject jsonObj4 = new JSONObject();
    jsonObj4.element("weather", jsonArray);
    System.out.println("jsonObj4:"+jsonObj4);
  }
}
Nach dem Login kopieren

Ausgabeergebnis:

jsonObj0:{"name0":"zhangsan","sex1":"female"}
 
jsonObj:{"name":"xuwei","sex":"male"}
 
jsonObj2:{"item0":{"name0":"zhangsan","sex1":"female"},"item1":{"name":"xuwei","sex":"male"}}
 
jsonObj3:{"j3":{"item0":{"name0":"zhangsan","sex1":"female"},"item1":{"name":"xuwei","sex":"male"}}}
 
jsonArray:[{"name":"xuwei","sex":"male"}]
 
jsonObj4:{"weather":[{"name":"xuwei","sex":"male"}]}
Nach dem Login kopieren

Die obige Methode zum Empfangen und Konvertieren von Array-Objekten durch js in Java Dies ist Der gesamte Inhalt, den der Herausgeber mit Ihnen geteilt hat, kann Ihnen eine Referenz geben und ich hoffe, dass Sie die chinesische PHP-Website unterstützen.

Weitere verwandte Artikel darüber, wie js Array-Objekte in Java empfängt und konvertiert, finden Sie auf der chinesischen PHP-Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ersetzen Sie Stringzeichen in JavaScript Ersetzen Sie Stringzeichen in JavaScript Mar 11, 2025 am 12:07 AM

Detaillierte Erläuterung der Methode für JavaScript -Zeichenfolge und FAQ In diesem Artikel werden zwei Möglichkeiten untersucht, wie String -Zeichen in JavaScript ersetzt werden: Interner JavaScript -Code und interne HTML für Webseiten. Ersetzen Sie die Zeichenfolge im JavaScript -Code Die direkteste Möglichkeit ist die Verwendung der Ersatz () -Methode: str = str.replace ("find", "ersetzen"); Diese Methode ersetzt nur die erste Übereinstimmung. Um alle Übereinstimmungen zu ersetzen, verwenden Sie einen regulären Ausdruck und fügen Sie das globale Flag G hinzu:: STR = Str.Replace (/fi

JQuery überprüfen, ob das Datum gültig ist JQuery überprüfen, ob das Datum gültig ist Mar 01, 2025 am 08:51 AM

Einfache JavaScript -Funktionen werden verwendet, um zu überprüfen, ob ein Datum gültig ist. Funktion isvaliddate (s) { var bits = ssplit ('/'); var d = neues Datum (Bits [2] '/' Bits [1] '/' Bits [0]); return !! (d && (d.getMonth () 1) == Bits [1] && d.getDate () == Nummer (Bits [0])); } //prüfen var

JQuery Get Element Polsterung/Rand JQuery Get Element Polsterung/Rand Mar 01, 2025 am 08:53 AM

In diesem Artikel wird erläutert, wie JQuery verwendet wird, um die inneren Rand- und Randwerte von DOM -Elementen zu erhalten und festzulegen, insbesondere die spezifischen Orte des äußeren Randes und der inneren Ränder des Elements. Während es möglich ist, die inneren und äußeren Ränder eines Elements mit CSS einzustellen, kann es schwierig sein, genaue Werte zu erhalten. // aufstellen $ ("Div.Header"). CSS ("Margin", "10px"); $ ("Div.Header"). CSS ("Padding", "10px"); Sie könnten denken, dieser Code ist

10 JQuery Accords Registerkarten 10 JQuery Accords Registerkarten Mar 01, 2025 am 01:34 AM

In diesem Artikel werden zehn außergewöhnliche JQuery -Registerkarten und Akkordeons untersucht. Der wichtigste Unterschied zwischen Registerkarten und Akkordeons liegt in der angezeigten und versteckten Inhaltsplatten. Lassen Sie uns mit diesen zehn Beispielen befassen. Verwandte Artikel: 10 JQuery Registerkarte Plugins

10 lohnt 10 lohnt Mar 01, 2025 am 01:29 AM

Entdecken Sie zehn außergewöhnliche JQuery -Plugins, um die Dynamik und die visuelle Anziehungskraft Ihrer Website zu verbessern! Diese kuratierte Sammlung bietet verschiedene Funktionen, von Bildanimation bis hin zu interaktiven Galerien. Lassen Sie uns diese leistungsstarken Tools untersuchen: Verwandte Beiträge: 1

HTTP-Debugging mit Knoten und HTTP-Konsole HTTP-Debugging mit Knoten und HTTP-Konsole Mar 01, 2025 am 01:37 AM

HTTP-Console ist ein Knotenmodul, mit dem Sie eine Befehlszeilenschnittstelle zum Ausführen von HTTP-Befehlen erhalten. Es eignet sich hervorragend zum Debuggen und dem genauen Sehen, was mit Ihren HTTP

Benutzerdefinierte Google -Search -API -Setup -Tutorial Benutzerdefinierte Google -Search -API -Setup -Tutorial Mar 04, 2025 am 01:06 AM

Dieses Tutorial zeigt Ihnen, wie Sie eine benutzerdefinierte Google -Such -API in Ihr Blog oder Ihre Website integrieren und ein raffinierteres Sucherlebnis bieten als Standard -WordPress -Themen -Suchfunktionen. Es ist überraschend einfach! Sie können die Suche auf y beschränken

JQuery fügen Sie Scrollbar zu Div hinzu JQuery fügen Sie Scrollbar zu Div hinzu Mar 01, 2025 am 01:30 AM

Mit dem folgenden JQuery -Code -Snippet können Scrollbars hinzugefügt werden, wenn der Div -Inhalt den Containerelementbereich überschreitet. (Keine Demonstration, bitte kopieren Sie es direkt nach Firebug) // d = Dokument // W = Fenster // $ = jQuery var contentArea = $ (this), wintop = contentArea.scrolltop (), docheight = $ (d) .height (), winHeight = $ (w) .height (), Divheight = $ ('#c

See all articles