2014-05-30 04:13:37 +08:00
|
|
|
<!DOCTYPE HTML>
|
|
|
|
<html>
|
|
|
|
<head>
|
2015-12-25 03:20:50 +08:00
|
|
|
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
|
2014-05-30 04:13:37 +08:00
|
|
|
|
2015-03-01 04:02:39 +08:00
|
|
|
<link href="../dist/jsoneditor.css" rel="stylesheet" type="text/css">
|
|
|
|
<script src="../dist/jsoneditor.js"></script>
|
2014-05-30 04:13:37 +08:00
|
|
|
|
2015-12-25 03:20:50 +08:00
|
|
|
<style type="text/css">
|
2014-05-30 04:13:37 +08:00
|
|
|
body {
|
|
|
|
font: 10.5pt arial;
|
|
|
|
color: #4d4d4d;
|
|
|
|
line-height: 150%;
|
|
|
|
width: 500px;
|
2015-12-31 00:26:39 +08:00
|
|
|
padding-left: 40px;
|
2014-05-30 04:13:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
code {
|
|
|
|
background-color: #f5f5f5;
|
|
|
|
}
|
|
|
|
|
|
|
|
#jsoneditor {
|
2018-08-25 21:31:58 +08:00
|
|
|
width: 500px;
|
|
|
|
height: 500px;
|
2014-05-30 04:13:37 +08:00
|
|
|
}
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Switch editor mode using the mode box.
|
|
|
|
Note that the mode can be changed programmatically as well using the method
|
|
|
|
<code>editor.setMode(mode)</code>, try it in the console of your browser.
|
|
|
|
</p>
|
|
|
|
|
2016-01-20 04:52:52 +08:00
|
|
|
<form>
|
|
|
|
<div id="jsoneditor"></div>
|
|
|
|
</form>
|
2014-05-30 04:13:37 +08:00
|
|
|
|
2020-03-18 17:47:34 +08:00
|
|
|
<p>
|
|
|
|
<button id="update">Update</button>
|
|
|
|
</p>
|
|
|
|
|
2015-02-28 04:54:04 +08:00
|
|
|
<script>
|
2014-05-30 04:13:37 +08:00
|
|
|
var container, options, json, editor;
|
|
|
|
|
|
|
|
container = document.getElementById('jsoneditor');
|
|
|
|
|
|
|
|
options = {
|
|
|
|
mode: 'tree',
|
2019-07-09 02:00:34 +08:00
|
|
|
modes: ['code', 'form', 'text', 'tree', 'view', 'preview'], // allowed modes
|
2015-12-25 18:38:41 +08:00
|
|
|
onError: function (err) {
|
2020-07-01 16:45:09 +08:00
|
|
|
console.error(err);
|
2014-05-30 04:13:37 +08:00
|
|
|
alert(err.toString());
|
2015-12-25 00:22:01 +08:00
|
|
|
},
|
2016-01-13 00:25:33 +08:00
|
|
|
onChange: function () {
|
|
|
|
console.log('change');
|
|
|
|
},
|
2018-08-07 17:03:27 +08:00
|
|
|
onChangeJSON: function (json) {
|
|
|
|
console.log('onChangeJSON', json);
|
2020-05-10 18:06:50 +08:00
|
|
|
|
|
|
|
// test feedback loop which is typical in React -> should not change anything
|
|
|
|
editorTest.update(json)
|
2018-08-07 17:03:27 +08:00
|
|
|
},
|
|
|
|
onChangeText: function (text) {
|
|
|
|
console.log('onChangeText', text);
|
|
|
|
},
|
2019-11-25 02:41:08 +08:00
|
|
|
onFocus: function(event) {
|
|
|
|
console.log("Focus : ",event);
|
|
|
|
},
|
|
|
|
onBlur: function(event) {
|
|
|
|
console.log("Blur : ",event);
|
|
|
|
},
|
2015-12-25 03:20:50 +08:00
|
|
|
indentation: 4,
|
2020-07-01 16:58:29 +08:00
|
|
|
// escapeUnicode: true,
|
2020-05-24 22:02:04 +08:00
|
|
|
limitDragging: true
|
2014-05-30 04:13:37 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
json = {
|
2015-12-31 00:26:39 +08:00
|
|
|
"array": [1, 2, [3,4,5]],
|
2014-05-30 04:13:37 +08:00
|
|
|
"boolean": true,
|
2018-08-22 18:10:15 +08:00
|
|
|
"color": "#82b92c",
|
2015-12-21 21:39:15 +08:00
|
|
|
"htmlcode": '"',
|
2015-12-25 00:22:01 +08:00
|
|
|
"escaped_unicode": '\\u20b9',
|
2020-07-01 16:58:29 +08:00
|
|
|
"unicode": '\u{1F600},\uD83D\uDCA9',
|
2015-12-25 00:22:01 +08:00
|
|
|
"return": '\n',
|
2014-05-30 04:13:37 +08:00
|
|
|
"null": null,
|
|
|
|
"number": 123,
|
|
|
|
"object": {"a": "b", "c": "d"},
|
2015-12-28 00:36:59 +08:00
|
|
|
"string": "Hello World",
|
2018-08-23 00:00:56 +08:00
|
|
|
"timestamp": 1534952749890,
|
2020-07-01 16:45:09 +08:00
|
|
|
"url": "http://jsoneditoronline.org",
|
|
|
|
"<button onclick=alert('oopsie!!!')>test xss</button>": "xss?",
|
|
|
|
"xss array": [
|
|
|
|
{
|
|
|
|
"<button onclick=alert('oopsie!!!')>test xss</button>": "xss?"
|
|
|
|
}
|
|
|
|
]
|
2014-05-30 04:13:37 +08:00
|
|
|
};
|
|
|
|
|
2018-11-14 03:39:02 +08:00
|
|
|
editorTest = new JSONEditor(container, options, json);
|
2015-12-25 00:22:01 +08:00
|
|
|
|
2015-12-25 03:20:50 +08:00
|
|
|
console.log('json', json);
|
|
|
|
console.log('string', JSON.stringify(json));
|
2020-03-18 17:47:34 +08:00
|
|
|
|
|
|
|
|
|
|
|
const update = document.getElementById('update')
|
|
|
|
update.onclick = function () {
|
|
|
|
const json2 = {
|
|
|
|
"array": [1, 2, [3,4,5]],
|
|
|
|
"array2": [1, 2, [3,4,5]],
|
|
|
|
"url": "http://jsoneditoronline.org",
|
|
|
|
"boolean": true,
|
|
|
|
"color": "#82b92c",
|
|
|
|
"htmlcode": '"',
|
|
|
|
"escaped_unicode": '\\u20b9',
|
|
|
|
"unicode": '\u20b9,\uD83D\uDCA9',
|
|
|
|
"return": '\n',
|
|
|
|
"null": null,
|
|
|
|
"number": 123,
|
|
|
|
"object": {"a": "b", "c": "d"},
|
|
|
|
"string": "Hello World",
|
|
|
|
"timestamp": 1534952749890
|
|
|
|
};
|
|
|
|
|
|
|
|
editorTest.update(json2)
|
|
|
|
}
|
2014-05-30 04:13:37 +08:00
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|