コンテンツへスキップ
メニュー
この質問にフラグが付けられました
2 返信
7132 ビュー

How does Odoo parse the options string from a widget in Javascript?

I have a widget with

options = "{'city': 'city', 'street_name': 'street', 'zip': 'zip'}" in the xml

When i write JSON.parse(options) in JS, i get an error: JSON.parse: expected property name or '}'.


But, if i write,

options = '{"city": "city", "street_name": "street", "zip": "zip"}' 

it works fine!


How does Odoo handle this. I want JSON to parse my string irrespective of the quotes..

アバター
破棄
最善の回答

Try to parse with `pyUtils`.

it provided some convience function for converting python-like data to js-like.

Search py_eval() / pyeval() in Odoo u should find some examples.



var pyUtils = require('web.py_utils')

// pass some custom options from xml to js _testFunction: function () {   
    var options = pyUtils.py_eval(node.attrs.options)
}


アバター
破棄
最善の回答

JS Parse replace single quote to double quote globally.

var res = JSON.parse(object.replace(/'/g, '"'));

console.log("city", res.city);

https://stackoverflow.com/questions/36038454/parsing-string-as-json-with-single-quotes



アバター
破棄
関連投稿 返信 ビュー 活動
1
8月 16
4594
2
3月 15
300
0
3月 15
3722
0
2月 21
3022
2
10月 19
9048