我需要从 html 元素属性解析一个对象(就像 angular 那样)而不使用 JSON.parse 或其他东西
例如我有一个DIV
这样的
<div some-attribute="{key1: 1 > 0, key2: true || false}"></div>
解析后,我只需要这个对象中所有内容的字符串表示:
{'key1': '1 > 0', 'key2': 'true || false'}
有没有能力在不发明新的解析器的情况下以这种方式解析它?
谢谢大家,我意识到我应该为此创建一个解析器。这是第一个版本(在 Coffee,不是纯 JS)
class Parser
self = @
constructor: ->
@quotes: '\'"`'
@object: (dataStr) ->
dataStr = $dp.fn.trim dataStr
if dataStr[0] isnt '{' or dataStr.slice(-1) isnt '}'
return null
dataStr = dataStr.slice 1, dataStr.length - 1
o = {}
pair =
key: ''
value: ''
addPair = ->
o[$dp.fn.trim(pair.key)] = $dp.fn.trim pair.value
pair.key = pair.value = ''
quoteOpened = null
underCursor = 'key'
for ch, i in dataStr
skip = false
if ch in self.quotes
unless quoteOpened
quoteOpened = ch
skip = true
else if quoteOpened and ch is quoteOpened
quoteOpened = null
skip = true
unless quoteOpened
switch
when ch is ':'
underCursor = 'border'
when underCursor is 'border' and not /\s/.test ch
underCursor = 'value'
when ch is ','
underCursor = 'key'
addPair()
skip = true
pair[underCursor] += ch if underCursor isnt 'border' and not skip
addPair() if pair.key or pair.value
o
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句