From 3885c929a097762a77fab85924d03872f5abaeed Mon Sep 17 00:00:00 2001 From: Jxck Date: Thu, 21 Apr 2016 15:30:01 +0900 Subject: [PATCH] fix parsing alone unary inline tag fixing #14 --- src/html2json.js | 2 +- test/test.js | 21 ++++++++++++++++++++- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/src/html2json.js b/src/html2json.js index f35adbc..85579e6 100644 --- a/src/html2json.js +++ b/src/html2json.js @@ -65,7 +65,7 @@ // if this tag dosen't have end tag // like // add to parents - var parent = bufArray[0]; + var parent = bufArray[0] || results; if (parent.child === undefined) { parent.child = []; } diff --git a/test/test.js b/test/test.js index 5bb02f5..eff1f16 100644 --- a/test/test.js +++ b/test/test.js @@ -22,6 +22,20 @@ describe('html2json', function() { assert.deepEqual(html, json2html(json)); }); + it('should parse hr', function() { + var json = { + node: 'root', + child: [ + { node: 'element', tag : 'hr' } + ] + }; + var html = '
'; + + assert.deepEqual(json, html2json(html)); + assert.deepEqual(html, json2html(json)); + }); + + it('should parse multi div', function() { var json = { node: 'root', @@ -385,6 +399,10 @@ describe('html2json', function() { attr: { id: 'execute', type: 'button', value: 'execute' } } ] + }, + { + node: 'element', + tag: 'hr', } ] }; @@ -394,7 +412,8 @@ describe('html2json', function() { + '
foo
' + '
goo
' + '' - + ''; + + '' + + '
'; assert.deepEqual(json, html2json(html)); assert.deepEqual(html, json2html(json));