1

我的递归函数正在中断,我不知道为什么。我正在尝试使用准系统 javascript 为 json 编写一个解析器到 css 并且似乎无法理解为什么我的函数不起作用。谁能帮我一把?

在 css 中,您将获得属于您正在处理的特定元素的子元素,如下所示

#nav li{
  some style here
}

试图在 javascript 中操作相同的东西是行不通的。到目前为止,我的代码适用于简单的选择器。

var json = {
    "body" : {
        "background": "#303030",
        "color": "#FFFFFF",
        "font-family": "Arial, Helvetica, sans-serif"
    },
    "#nav": {
        "li": {
            "display": "inline-block",
            "list-styles": "none",
            "margin-right": "10px",
            "padding": "10px, 10px"
        }
    }
}
// How to use:
// json is an obj
// body is a selector
// background is a property belong to a selector
// #303030 is a value for the property


//apply css changes to document without writing any css
//by default the first values are
//               selector = background
//               parent   = document
//               object   = json
function styleApply(selector, parent, object){
    var element, onSelector, signal;

    //checks the first character of the selector and grabs element from page depending on what type of element it is
    switch(selector[0]){
        case ".":
            element= parent.getElementsByClassName(selector.substring(1));
            newParent = element[0]; //checks to see what is in the first index of the obtained element
            break;
        case "#":
            element= parent.getElementById(selector.substring(1));
            newParent = element;
            break;
        default:
            element= parent.getElementsByTagName(selector);
            newParent = element[0];
            break;
    }

    //only works if there is actually an element in the page corresponding with the selector
    if(newParent != null){ 
        //loops through all elements with the same selector or in the case of id just does one loop
        for(var i=0; i<element.length; i++){ 

            //loops through all properties in the selector
            for (var property in object[selector]){
                //grabs the associated value with the selector could be string or object
                var value= object[selector][property];

                //if it is a string it is a style, if it is an object, it is targeting the elements inside the current selector only
                if(typeof(value) === "string"){
                    element[i].style.setProperty(property, value);
                }else{

/*I am breaking my code right here*/

                    //reusing the same function, this time selector is equal to property for the case of nav, it is the element 'li'
                    //newParent is the element who is a parent of the current element (e.g 'nav' is parent of 'li')
                    //value is the new object that is replacing json, 
                    styleApply(property, newParent, value); //since value is an object it did not pass the string test and now the new object is value
/*Problem ends here */


                }
            }
        }
    } 
}

my code for looping over all the values in json
for (var selector in json){
    styleApply(selector, document, json);
}
4

2 回答 2

1

我只是碰巧研究了 json 来编写一个比直接将字符串和数字连接在一起更干净的 css。我没有将样式直接应用于每个元素,而是将它们放入一个<style>元素中,这样可以更轻松地在页面的整个生命周期中进行更改。它还能够定位伪元素,例如我使用的 :before。

无论如何,这是功能:

// convert json to css
function jsonToCss(obj) {
    var x, finalStr=''
    for (x in obj) {
        var y, decStr=''
        for (y in obj[x]) {
            decStr+= y + ':' + obj[x][y] + ';'
        }
        finalStr+= x + '{' + decStr + '}'
    }
    return finalStr
}

由于该函数仅通过两个级别递归(一个用于选择器,一个用于声明),因此您的 json 需要进行如下修改:

var json = {
    "body" : {
        "background": "#303030",
        "color": "#FFFFFF",
        "font-family": "Arial, Helvetica, sans-serif"
    },
    "#nav li": {
        "display": "inline-block",
        "list-styles": "none",
        "margin-right": "10px",
        "padding": "10px, 10px"
    }
}

将其输入函数,您将获得以下字符串:

body{background:#303030;color:#FFFFFF;font-family:Arial, Helvetica, sans-serif;}#nav li{display:inline-block;list-styles:none;margin-right:10px;padding:10px, 10px;}

然后您可以将其放入样式元素中。我还没有验证该函数生成的字符串以查看它是否格式正确,但它对我来说效果很好。

于 2015-01-20T18:19:29.377 回答
0

这是我读到的关于将 json 解析为 css 的简短代码,我想尝试一下

-- 选择器指的是你用 json 写的 css 选择器

-- parent 开始引用文档,就像在 javascript 中的 Document 对象模型中一样

--object是传入的json对象

如果我滥用任何行话,请再次纠正我

function styleApply(selector, parent, object){
    var element, onSelector, signal;
    
    switch(selector[0]){
        case ".":
            element= parent.getElementsByClassName(selector.substring(1));
            break;
        case "#":
            element= [parent.getElementById(selector.substring(1))];
            break;
        default:
            element= parent.getElementsByTagName(selector);
            break;
    }
    
    if(element[0] != null){
        for(var i=0; i<element.length; i++){ 
            for (var property in object[selector]){
            
                var value= object[selector][property];

                if(typeof(value) === "string"){
                    element[i].style.setProperty(property, value);
                }else{
                    styleApply(property, element[i], object[selector]);
                }
            }
        }
    } 
}
于 2014-03-24T23:53:30.557 回答