Skip to content

anhthang/vscode-xml2json

Repository files navigation

XML to JSON

Convert XML from clipboard or current document/selection to JSON

Version Installs Downloads Rating

Are you using Code and working with XML builder tools day by day?

XML to JSON can help you create the final object, just edit the variables that need dynamic data instead of typing each object key, attribute and no typos mistake. Converted data can be use for xmlbuilder, xml2js or your expected format using configuration options.

Here are just some of the features that XML to JSON provides:

  • Convert XML from document or selection to JSON
  • Convert XML from clipboard to JSON

📝 Changelog

See the release notes for the full set of changes

🏙 Preview

png

🔧 Configuration

By default, it's following xml2js default options. If you wanna change, choose one of pre-defined options (eg: xmlbuilder) or select custom and edit in settings.json. Below is an example:

{
    "xml2json.defaultSettings": "custom",
    "xml2json.options": {
        "attrkey": "@",
        "explicitArray": false,
        "mergeAttrs": true
    }
}

Availablie options:

Following xml2js

Name Default Description
attrkey $ Prefix that is used to access the attributes. Version 0.1 default was @.
charkey _ Prefix that is used to access the character content. Version 0.1 default was #.
explicitCharkey false
trim false Trim the whitespace at the beginning and end of text nodes.
normalizeTags false Normalize all tag names to lowercase.
normalize false Trim whitespaces inside text nodes.
explicitRoot true Set this if you want to get the root node in the resulting object.
emptyTag what will the value of empty nodes be.
explicitArray true Always put child nodes in an array if true; otherwise an array is created only if there is more than one.
ignoreAttrs false Ignore all XML attributes and only create text nodes.
mergeAttrs false Merge attributes and child elements as properties of the parent, instead of keying attributes off a child attribute object. This option is ignored if ignoreAttrs is false.
validator null You can specify a callable that validates the resulting structure somehow, however you want. See unit tests for an example.
xmlns false Give each element a field usually called '$ns' (the first character is the same as attrkey) that contains its local name and namespace URI.
explicitChildren false Put child elements to separate property. Doesn't work with mergeAttrs = true. If element has no children then children won't be created. Added in 0.2.5.
childkey $$ Prefix that is used to access child elements if explicitChildren is set to true. Added in 0.2.5.
preserveChildrenOrder false Modifies the behavior of explicitChildren so that the value of the children property becomes an ordered array. When this is true, every node will also get a #name field whose value will correspond to the XML nodeName, so that you may iterate the children array and still be able to determine node names. The named (and potentially unordered) properties are also retained in this configuration at the same level as the ordered children array. Added in 0.4.9.
charsAsChildren false Determines whether chars should be considered children if explicitChildren is on. Added in 0.2.5.
includeWhiteChars false Determines whether whitespace-only text nodes should be included. Added in 0.4.17.
async false Should the callbacks be async? This might be an incompatible change if your code depends on sync execution of callbacks. Future versions of xml2js might change this default, so the recommendation is to not depend on sync execution anyway. Added in 0.2.6.
strict true Set sax-js to strict or non-strict parsing mode. Defaults to true which is highly recommended, since parsing HTML which is not well-formed XML might yield just about anything. Added in 0.2.7.
attrNameProcessors(*) null Allows the addition of attribute name processing functions. Accepts an Array of functions. Added in 0.4.14.
attrValueProcessors(*) null Allows the addition of attribute value processing functions. Accepts an Array of functions. Added in 0.4.1.
tagNameProcessors(*) null Allows the addition of tag name processing functions. Accepts an Array of functions. Added in 0.4.1.
valueProcessors(*) null Allows the addition of element value processing functions. Accepts an Array of functions. Added in 0.4.6.

Note

(*): These configuration is not supported this time due to Code extension only support array, boolean, integer, null, number, object, string.

📸 Screenshots

png png

📝 Icon Credit

XML, JSON file icon by Smashicons from Flaticon - Flaticon Basic License

Releases

No releases published

Packages

No packages published