开发者

jQuery CSS generator- Update CSS output?

开发者 https://www.devze.com 2023-02-08 19:26 出处:网络
开发者_运维知识库I am playing around with jQuery and thought I would build a little css generator.
开发者_运维知识库

I am playing around with jQuery and thought I would build a little css generator.

Currently you can see that when you make a change it just appends the change, I would like it so it in a sense updates the css output instead of adding to it. so instead of..

textarea{
font-size: 18px;

}textarea{
color: green;

}

it would be:

textarea{
font-size: 18px;
color: green;
}

http://jsfiddle.net/MSSJQ/3/

This is what I have rocking so far.


UPDATED

just a proof of concept, but you can get the idea...

  • DEMO: https://so.lucafilosofi.com/jquery-css-generator-update-css-output
$(function() {
    $('#textarea').updateStyle();
});

(function($){  
$.fn.updateStyle = function(options) {
    var defaults = {
        controls: '#controls p a',
        codewrapper: '#code'
    };
    var options = $.extend(defaults, options);
    return this.each(function() {
        $elm = $(this);
        var element = $elm.attr('type');
        $(options.controls).click(function(e) {
            e.preventDefault();
            var control_class = $(this).attr("class");
            var property_value = $(this).text();
            var css_property = control_class + ': ' + property_value + '; ';
            var property_wrapper = '.' + control_class;
            var html = '<span class="' + control_class + '">' + css_property + '<span>';
            var $outer = $('#' + element + '-outer');
            var $inner = $('#' + element + '-inner');
            if ($outer.length) {
                if ($outer.find(property_wrapper).length) {
                    $outer.find(property_wrapper).html(css_property);
                } else {
                    $inner.append(html);
                }
            } else {
                $(options.codewrapper).append('<div id="' + element + '-outer">' + 
                  element + ' {' + '<div id="' + element + '-inner">' + html + 
                  '</div> }</div>');
            }
            $elm.attr('style', $inner.text());
        });
    });
};
})(jQuery);
0

精彩评论

暂无评论...
验证码 换一张
取 消