浮动标签和Javascript切换HTML和CSS问题

时间:2018-01-23 16:57:53

标签: javascript jquery html css

我在CSSScript上找到了一个适合即将推出的项目的浮动标签脚本,但是我'有问题将JS与切换CSS样式的HTML分离开来。

这里是JSFiddle DEMO所以你可以理解这个场景。

这里只是JS脚本的一小部分,用于执行"样式"之间的切换。在上面引用的演示链接中还有一个主要的JS组件来处理样式。

new FloatLabels('.form-1', {
  style: 1
});
document.querySelectorAll('input[name="style"]').forEach(function(el) {
  el.addEventListener('change', function(ev) {
    var form = ev.target.closest('form');
    form.className = form.className.replace(/\b fl-style-\d\b/g, '') + ' ' + 
ev.target.value;
  }, false);
});

以下是从中挑选CSS样式的HTML表单:

<form class="form-1">
  <div class="col-xs-12 col-sm-12 col-md-12 col-lg-12">
    <div class="row">
      <div class="col-xs-12 col-sm-6 col-md-6 col-lg-6">
        <label for="firstnamelabel">First Name</label>
        <input type="text" id="firstnamelabel" placeholder="First Name" value="" required />
      </div>
      <div class="col-xs-12 col-sm-6 col-md-6 col-lg-6">
        <label for="lastnamelabel">Last Name</label>
        <input type="text" id="lastnamelabel" placeholder="Last Name" value="" required />
      </div>
    </div>
    <div class="row">
      <div class="col-xs-12 col-sm-12 col-md-12">
        <label for="commentslabel">Enter some content</label>
        <textarea id="commentslabel" placeholder="Comments" rows="4" autocomplete="off" required></textarea>
        <label for="select-1">Select an option</label>
        <select id="select-1" class="required" required>
          <option value="1">Option 1</option>
          <option value="2">Option 2</option>
          <option value="3">Option 3</option>
        </select>
      </div>
    </div>
  </div>
  <input type="radio" name="style" id="style-0" value="fl-style-0" />
  <label for="style-0">Default Style</label>
  <input type="radio" name="style" id="style-1" value="fl-style-1" checked />
  <label for="style-1">Style 1</label>
  <input type="radio" name="style" id="style-2" value="fl-style-2" />
  <label for="style-2">Style 2</label>
  <button type="reset" class="button large">Reset</button>
  <button type="submit" class="button large">Submit</button>
</form>

在表单底部,您可以在CSS样式(默认,样式1和样式2)之间切换,效果很好。

问题是,在我的模型上,我无法为用户提供选项。我需要展示浮动标签功能,以便利益相关者可以决定哪种风格符合他们的喜好,但是一旦利益相关者在风格1或风格2之间选择,我似乎无法找到一种方法来解开js切换并设置风格

理想解决方案:在利益相关者选择样式1或样式2之后,我需要能够设置css样式。显然,我需要保留与所选样式相关的所有功能。

任何人都可以帮忙解决这个问题吗?我真的很感激任何帮助!

3 个答案:

答案 0 :(得分:1)

用于确定样式的JavaScript逻辑位于小提琴的JS部分的底部。

//STYLES TOGGLE
new FloatLabels('.form-1', {
  style: 1
});
document.querySelectorAll('input[name="style"]').forEach(function(el) {
  el.addEventListener('change', function(ev) {
    var form = ev.target.closest('form');
    form.className = form.className.replace(/\b fl-style-\d\b/g, '') + ' ' + ev.target.value;
  }, false);
});

如果您不希望行为切换,可以删除底部块(以document.querySelectorAll(...)开头的部分)并保留以下内容:

new FloatLabels('.form-1', {
  style: 1
});

'.form-1'将是您要为其激活库的表单的CSS选择器,style属性将确定您要使用的两种样式中的哪一种。

如果你想真正整合东西,你也可以删除不需要的CSS,虽然听起来你的客户还没有决定他们喜欢哪种风格,所以你不必担心。 :)

需要删除不需要的CSS时,我们假设您的客户选择了样式1:然后您可以通过CSS查看并删除以.fl-form.fl-style-2开头的规则,因为看起来JS对切换样式的唯一改变就是在<form>元素上切换一个类。

答案 1 :(得分:1)

这是漂浮标签的工作示例,请查看并告诉我您的反馈。 https://plnkr.co/edit/79G0zsRnkwuH6BQWDdm6?p=preview

  

的index.html

<!doctype html>
<html lang="en-us">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Float Labels by Gemini Labs</title>
    <link rel='stylesheet' href='https://fonts.googleapis.com/css?family=Open+Sans:400,700' type='text/css'>
    <link rel="stylesheet" href="demo/css/styles.css">
  </head>
  <body>
    <main class="main-content">

      <section class="section">
        <h2>Demo</h2>

        <form class="form-1">
          <label for="input-1">Enter a title</label>
          <input type="text" id="input-1" placeholder="Input" value="" required/>

          <label for="textarea-1">Enter some content</label>
          <textarea id="textarea-1" placeholder="Textarea" rows="4" autocomplete="off" required></textarea>

          <label for="select-1">Select an option</label>
          <select id="select-1" class="required">
            <option value="1">Option 1</option>
            <option value="2">Option 2</option>
            <option value="3">Option 3</option>
          </select>

          <input type="radio" name="style" id="style-0" value="0"/>
          <label for="style-0">Default Style</label>

          <input type="radio" name="style" id="style-1" value="1" checked/>
          <label for="style-1">Style 1</label>

          <input type="radio" name="style" id="style-2" value="2"/>
          <label for="style-2">Style 2</label>

          <div class="button-group">
            <button type="button" class="button large fl-toggle">Toggle Float Labels</button>
            <button type="reset" class="button large secondary">Reset form</button>
          </div>
        </form>
      </section>
       </main>
    <script src="src/float-labels.js"></script>
    <script src="demo/js/script.js"></script>
  </body>
</html>
  

CSS / style.css中

@-ms-viewport{width:device-width}html{font-size:100%;line-height:1.5em;-ms-overflow-style:scrollbar;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;box-sizing:border-box;-webkit-font-feature-settings:"liga" 1,"dlig" 1,"kern" 1;font-feature-settings:"liga" 1,"dlig" 1,"kern" 1;-webkit-font-kerning:normal;font-kerning:normal;-webkit-font-variant-ligatures:common-ligatures;font-variant-ligatures:common-ligatures;text-rendering:optimizeLegibility}@media print{html{font-size:12pt}}*,:after,:before{box-sizing:inherit}*{-webkit-overflow-scrolling:touch;outline:0}article,aside,figcaption,figure,footer,header,main,nav,section{display:block}[role=button],a,area,button,input,label,select,summary,textarea{-ms-touch-action:manipulation;touch-action:manipulation}audio,img,video{max-width:100%}img,video{height:auto}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}canvas{display:inline-block}svg{max-height:100%}svg:not(:root){overflow:hidden}iframe{border:none}table{border-collapse:collapse}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}input[type=checkbox],input[type=radio]{box-sizing:border-box;font-size:112.5%;margin-right:3px}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{resize:vertical;overflow:auto}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}[tabindex="-1"]:focus{outline:none!important}[hidden]{display:none!important}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;white-space:normal}::-moz-focus-inner{border:0;padding:0}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus,a:not([href]):not([tabindex]):hover{color:inherit;text-decoration:none;outline:0}body{margin:0 auto;font-family:Open Sans,sans-serif;color:#424242}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:Open Sans,sans-serif;letter-spacing:-.03125em;margin:0 0 1.5rem;color:#212121}.h1,h1{font-size:1.77687rem}.h1,.h2,h1,h2{line-height:1.5rem;font-weight:700}.h2,h2{font-size:1.60181rem}.h3,h3{font-size:1.125rem}.h3,.h4,h3,h4{line-height:1.5rem;font-weight:700}.h4,h4{font-size:1rem}.h5,h5{font-size:1.333rem}.h5,.h6,h5,h6{line-height:1.5rem;font-weight:700}.h6,h6{font-size:1.125rem;text-transform:uppercase}blockquote,ol,p,pre,table,ul{margin:0 0 1.5rem}p{font-size:1rem;line-height:1.5rem}blockquote{position:relative;line-height:2.25rem;padding:.75rem 1.5rem}blockquote p{margin:0;font-size:1.125rem}cite{display:block}small{font-size:.88887rem;line-height:1}ol ol,ol ul,ul ol,ul ul{margin:0}dd{margin:0 0 .75rem}dt{font-weight:700}sub,sup{position:relative;line-height:0;vertical-align:baseline;font-size:.88887rem}sub{bottom:-.1875rem}sup{top:-.375rem}abbr[title]{border-bottom:.1em dotted currentColor;cursor:help}code,kbd{padding:2px 4px;line-height:1}code,kbd,pre{border-radius:3px}pre{display:block;word-wrap:normal;overflow:scroll;-webkit-overflow-scrolling:touch;padding:.375rem .75rem;margin-bottom:1.5rem}pre code{padding:0;word-break:normal;white-space:pre}.button{background-color:#212121;border-color:#212121}.button i{margin-right:.1875rem}form{font-family:Open Sans,sans-serif;letter-spacing:-.03125em;margin:0 0 1.5rem}fieldset{position:relative;display:block;border:0 solid currentColor;padding:0;margin:0}legend{position:absolute;top:-24px;left:-1px;font-weight:400}label,legend{padding:0;font-size:.88887rem}label{display:inline-block;vertical-align:top;cursor:pointer;line-height:1.5rem}input,select,textarea{display:block;width:100%;outline:none;background-color:transparent;border:solid currentColor;border-radius:3px;font-size:.88887rem;line-height:1.5rem;padding:.375rem .75rem;border-width:1px;margin-top:-.0625rem;margin-bottom:1.4375rem}input:-moz-placeholder,input::-moz-placeholder,select:-moz-placeholder,select::-moz-placeholder,textarea:-moz-placeholder,textarea::-moz-placeholder{color:rgba(0,0,0,.5)}input:-ms-input-placeholder,select:-ms-input-placeholder,textarea:-ms-input-placeholder{color:rgba(0,0,0,.5)}input::-webkit-input-placeholder,select::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:rgba(0,0,0,.5)}input:active,input:focus,select:active,select:focus,textarea:active,textarea:focus{border-color:#212121}select{height:2.375rem}textarea{height:6.875rem}input[type=date],input[type=number],input[type=search]{box-sizing:border-box;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}input[type=checkbox],input[type=radio]{display:inline-block;position:relative;top:-1px;width:auto;padding:0;margin:0}input[type=checkbox]+label,input[type=radio]+label{display:inline-block;width:auto;padding:0;line-height:1.5rem;margin:0 1.5rem 1.5rem .1875rem}@font-face{font-family:Icons;font-style:normal;font-weight:400;src:url("data:application/x-font-ttf;charset=utf-8;base64,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") format("truetype")}[class*=" icon-"]:before,[class^=icon-]:before{top:1px;font-family:Icons!important;font-style:normal;font-variant:normal;font-weight:400;line-height:1;speak:none;text-transform:none}
.fl-form .fl-wrap,[class*=" icon-"]:before,[class^=icon-]:before{position:relative;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.fl-form .fl-wrap{text-rendering:optimizeLegibility}.fl-form input.fl-input,.fl-form select.fl-select,.fl-form textarea.fl-textarea{width:100%;outline:0;font-size:16px;line-height:1.5;border-radius:3px;border:1px solid #dfdfdf;background-color:#fff;box-sizing:border-box;transition:all .2s ease-in-out;margin-bottom:1.4375rem}.fl-form input.fl-input:-moz-placeholder,.fl-form input.fl-input::-moz-placeholder,.fl-form select.fl-select:-moz-placeholder,.fl-form select.fl-select::-moz-placeholder,.fl-form textarea.fl-textarea:-moz-placeholder,.fl-form textarea.fl-textarea::-moz-placeholder{color:#bbb}.fl-form input.fl-input:-ms-input-placeholder,.fl-form select.fl-select:-ms-input-placeholder,.fl-form textarea.fl-textarea:-ms-input-placeholder{color:#bbb}.fl-form input.fl-input::-webkit-input-placeholder,.fl-form select.fl-select::-webkit-input-placeholder,.fl-form textarea.fl-textarea::-webkit-input-placeholder{color:#bbb}.fl-form select.fl-select{position:relative;color:#bbb;cursor:pointer;-webkit-appearance:none;-moz-appearance:none}.fl-form .fl-is-active input.fl-input,.fl-form .fl-is-active select.fl-select,.fl-form .fl-is-active textarea.fl-textarea{color:#444;background-color:#fff;border-color:#dfdfdf}.fl-form .fl-has-focus input.fl-input,.fl-form .fl-has-focus select.fl-select,.fl-form .fl-has-focus textarea.fl-textarea{background-color:#fff;border-color:#1976d2}.fl-form label.fl-label{opacity:0;visibility:hidden;display:block;position:absolute;top:-12px;left:0;font-size:12px;font-weight:400;line-height:1;color:#bbb;border-radius-top-left:3px;transition:all .2s ease-in-out;z-index:1}.fl-form .fl-is-active label.fl-label{opacity:1;visibility:visible}.fl-form .fl-has-focus label.fl-label{color:#1976d2}.fl-form .fl-is-required:before{opacity:1;content:"*";display:block;position:absolute;top:1px;right:15px;font-size:16px;line-height:1.75;color:#d32f2f;transition:all .2s ease-in-out;padding:6px 0 0;z-index:1}.fl-form .fl-is-required.fl-is-active:before{opacity:0}.fl-form.fl-style-1 input.fl-input,.fl-form.fl-style-1 select.fl-select,.fl-form.fl-style-1 textarea.fl-textarea{padding:6px 12px}.fl-form.fl-style-1 select.fl-select{height:38px}.fl-form.fl-style-1 .fl-is-active input.fl-input,.fl-form.fl-style-1 .fl-is-active select.fl-select,.fl-form.fl-style-1 .fl-is-active textarea.fl-textarea{padding:6px 12px}.fl-form.fl-style-1 label.fl-label{top:1px;left:10px;background-color:transparent;padding:12px 3px}.fl-form.fl-style-1 label.fl-label:before{content:"";display:block;position:absolute;top:19px;left:0;right:0;height:1px;background-color:#fff;z-index:-1}.fl-form.fl-style-1 .fl-is-active label.fl-label{top:-9px;padding:3px}.fl-form.fl-style-1 .fl-is-active label.fl-label:before{top:9px}.fl-form.fl-style-2 input.fl-input,.fl-form.fl-style-2 select.fl-select,.fl-form.fl-style-2 textarea.fl-textarea{padding:12px}.fl-form.fl-style-2 select.fl-select{height:50px}.fl-form.fl-style-2 .fl-is-active input.fl-input,.fl-form.fl-style-2 .fl-is-active select.fl-select,.fl-form.fl-style-2 .fl-is-active textarea.fl-textarea{padding:18px 12px 6px}.fl-form.fl-style-2 label.fl-label{top:1px;left:10px;padding:6px 3px 3px}.fl-form.fl-style-2 .fl-is-required:before{padding-top:12px}.fl-form .fl-wrap-select:after{content:"";position:absolute;display:block;top:1px;right:6px;height:calc(100% - 2px);width:12px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 16'><path fill='#bbb' d='M 4 0 L 0 6.5 L 8 6.5 L 4 0 z M 0 9.5 L 4 16 L 4 16 L 8 9.5 z'/></svg>") no-repeat;background-position:100% 50%;background-size:7px 14px;z-index:2}a{color:#1565c0;text-decoration:none}a:hover{text-decoration:underline}blockquote{border-left:4px solid #eceff1;color:#455a64}blockquote p{font-size:.88887rem}blockquote p:not(:last-child){margin-bottom:.75rem}blockquote pre{margin-bottom:0}code{font-size:1rem;border-radius:3px;background-color:#eceff1;text-shadow:1px 1px 0 hsla(0,0%,100%,.75)}pre{line-height:1.5rem;font-weight:200;background-color:#263238}pre code{font-size:.88887rem;color:#dcedc8;text-shadow:1px 1px 0 rgba(33,33,33,.25);background:none}.page-header{padding:3rem 1.5rem;background-color:#263238;text-align:center}@media screen and (min-width:42em){.page-header{padding:3rem 4.5rem}}@media screen and (min-width:50em){.page-header{padding:6rem 4.5rem}}.page-header .button{background-color:rgba(69,90,100,.3);font-size:1rem;padding:.75rem 1.5rem;margin:1.125rem 0 0}.page-header .button,.page-header .button:hover{color:hsla(0,0%,100%,.7);border-color:transparent}.page-header .button:hover{background-color:rgba(69,90,100,.5)}.page-header .button:active{background-color:rgba(69,90,100,.7)}@media screen and (min-width:35em){.page-header .button{margin:1.125rem .375rem 0}}.page-footer{max-width:52em;margin:0 auto;padding:1.5rem}.page-footer p:first-child{position:relative;top:1px;font-weight:700;border-top:1px solid #eceff1;margin:-2px 0 0;padding-top:1.5rem}.main-content{max-width:52em;margin:0 auto;padding:2.25rem 1.5rem 0}.section ul{line-height:1.875rem}.section:not(:last-child){margin-bottom:3rem}.project-name{color:#fff}@media screen and (min-width:42em){.project-name{font-size:2.36856rem;line-height:3rem}}@media screen and (min-width:50em){.project-name{font-size:3.15731rem}}.project-tagline{color:hsla(0,0%,100%,.5);font-weight:400;font-size:1rem;margin-bottom:1.5rem}@media screen and (min-width:42em){.project-tagline{font-size:1.333rem;line-height:3rem;line-height:2.25rem}}.badge{display:inline-block;line-height:2.25rem;margin-bottom:1.5rem}.badge img{height:1.5rem}.button{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Open Sans,sans-serif;font-size:1rem;line-height:1.375rem;padding:.375rem 1.125rem;margin-bottom:1.5rem;position:relative;display:inline-block;text-align:center;cursor:pointer;border:1px solid transparent;border-radius:3px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:top;color:#fff;background-color:#1565c0;border-color:#1565c0;transition:color .125s ease-in-out,background-color .125s ease-in-out,border-color .125s ease-in-out}.button,.button:hover{text-decoration:none;outline:none}.button.disabled,.button[disabled]{opacity:.7;cursor:default}.button-group{display:inline-block;vertical-align:bottom}.button-group .button{float:left;z-index:1}.button-group .button:focus,.button-group .button:hover{z-index:2}.button-group .button.active,.button-group .button:active{z-index:3}.button-group .button:first-child{border-radius:3px 0 0 3px}.button-group .button:last-child{border-radius:0 3px 3px 0}.button-group .button:not(:first-child):not(:last-child){border-radius:0}.button-group .button:not(:first-child){margin-left:-1px}.button:hover{background-color:#104d92;border-color:#104d92}.button.active,.button:active{background-color:#0b3564;border-color:#0b3564}.button.disabled,.button[disabled]{color:#fff;background-color:#1565c0;border-color:#1565c0}.button:not([disabled]):not(.disabled):active{-webkit-transform:translate3d(0,1px,0);transform:translate3d(0,1px,0)}.button.secondary{color:#fff;background-color:#424242;border-color:#424242}.button.secondary:hover{background-color:#292929;border-color:#292929}.button.secondary.active,.button.secondary:active{background-color:#0f0f0f;border-color:#0f0f0f}.button.secondary.disabled,.button.secondary[disabled]{color:#fff;background-color:#424242;border-color:#424242}.button-group{display:block;margin-bottom:1.5rem}.button-group:after{content:"";display:table;clear:both}:not(.button-group)>.button{width:100%}@media screen and (min-width:35em){:not(.button-group)>.button{width:auto}}form .button{display:block;margin:0}
  

的src /浮子label.js

;(功能(窗口,文档,未定义)         {             “使用严格”;

        var Plugin = function( el, options )
        {
            this.el = this.isString( el ) ? document.querySelectorAll( el ) : [el];
            this.config = [];
            this.options = options;
            this.selectors = [];
            this.init();
            this.destroy = function() {
                this.loop( function( el ) {
                    el.removeEventListener( 'reset', this.events.reset );
                    this.removeClasses( el );
                }, function( field ) {
                    this.reset( field );
                });
            };
            this.rebuild = function() {
                this.loop( null, function( field ) {
                    this.floatLabel( field, true );
                });
            };
        };

        Plugin.prototype = {

            defaults: {
                customEvent: null,
                customLabel: null,
                customPlaceholder: null,
                exclude: '.no-label',
                inputRegex: /email|number|password|search|tel|text|url/,
                prefix: 'fl-',
                prioritize: 'label', // label|placeholder
                requiredClass: 'required',
                style: 0, // 0|1|2
                transform: 'input,select,textarea'
            },

            /** @return void */
            init: function()
            {
                this.initEvents();
                this.loop( function( el, i ) {
                    var style = this.config[i].style;
                    el.addEventListener( 'reset', this.events.reset );
                    el.classList.add( this.prefixed( 'form' ));
                    if( style ) {
                        el.classList.add( this.prefixed( 'style-' + style ));
                    }
                }, function( field ) {
                    this.floatLabel( field );
                });
            },

            /** @return void */
            initEvents: function()
            {
                this.events = {
                    blur: this.onBlur.bind( this ),
                    change: this.onInput.bind( this ),
                    focus: this.onFocus.bind( this ),
                    input: this.onInput.bind( this ),
                    reset: this.onReset.bind( this ),
                };
            },

            /** @return string */
            addRemove: function( bool )
            {
                return bool ? 'add' : 'remove';
            },

            /** @return null|void */
            build: function( el )
            {
                var labelEl = this.getLabel( el );
                if( !labelEl )return;
                el.classList.add( this.prefixed( el.tagName.toLowerCase() ));
                this.setLabel( labelEl, el );
                this.setPlaceholder( labelEl, el );
                this.wrapLabel( labelEl, el );
                this.handleEvents( el, 'add' );
                if( typeof this.config[this.current].customEvent === 'function' ) {
                    this.config[this.current].customEvent.call( this, el );
                }
            },

            /** @return Element */
            createEl: function( tag, attributes )
            {
                var el = ( typeof tag === 'string' ) ? document.createElement( tag ) : tag;
                attributes = attributes || {};
                for( var key in attributes ) {
                    if( !attributes.hasOwnProperty( key ))continue;
                    el.setAttribute( key, attributes[key] );
                }
                return el;
            },

            /** @return object */
            extend: function()
            {
                var args = [].slice.call( arguments );
                var result = args[0];
                var extenders = args.slice(1);
                Object.keys( extenders ).forEach( function( i ) {
                    for( var key in extenders[i] ) {
                        if( !extenders[i].hasOwnProperty( key ))continue;
                        result[key] = extenders[i][key];
                    }
                });
                return result;
            },

            /** @return null|void */
            floatLabel: function( el, rebuild )
            {
                if( !el.getAttribute( 'id' ) || (
                    el.tagName === 'INPUT' && !this.config[this.current].inputRegex.test( el.getAttribute( 'type' ))
                ))return;
                if( this.hasParent( el )) {
                    if( rebuild !== true )return;
                    this.reset( el );
                }
                this.build( el );
            },

            /** @return string|false */
            getLabel: function( el )
            {
                var label = 'label[for="' + el.getAttribute( 'id' ) + '"]';
                var labelEl = this.el[this.current].querySelectorAll( label );
                // check for multiple labels with identical 'for' attributes
                if( labelEl.length > 1 ) {
                    labelEl = el.parentNode.querySelectorAll( label );
                }
                if( labelEl.length === 1 ) {
                    return labelEl[0];
                }
                return false;
            },

            /** @return string */
            getLabelText: function( labelEl, el )
            {
                var labelText = labelEl.textContent.replace( /[*:]/g, '' ).trim();
                var placeholderText = el.getAttribute( 'placeholder' );
                if( !labelText || ( labelText && placeholderText && this.config[this.current].prioritize === 'placeholder' )) {
                    labelText = placeholderText;
                }
                return labelText;
            },

            /** @return void */
            handleEvents: function( el, action )
            {
                var events = this.events;
                ['blur','input','focus'].forEach( function( event ) {
                    if( el.type === 'file' && event === 'input' ) {
                        event = 'change';
                    }
                    el[ action + 'EventListener']( event, events[event] );
                });
            },

            /** @return bool */
            hasParent: function( el )
            {
                return el.parentNode.classList.contains( this.prefixed( 'wrap' ));
            },

            /** @return bool */
            isString: function( str ) {
                return Object.prototype.toString.call( str ) === "[object String]";
            },

            /** @return void */
            loop: function( elCallback, fieldCallback ) {
                for( var i = 0; i < this.el.length; ++i ) {
                    if( typeof this.selectors[i] === 'undefined' ) {
                        var config = this.extend( {}, this.defaults, this.options, this.el[i].getAttribute( 'data-options' ));
                        var exclude = ':not(' + config.exclude.split( /[\s,]+/ ).join( '):not(' ) + ')';
                        this.selectors[i] = config.transform.replace( /,/g, exclude + ',' ) + exclude;
                        this.config[i] = config;
                    }
                    var fields = this.el[i].querySelectorAll( this.selectors[i] );
                    this.current = i;
                    if( typeof elCallback === 'function' ) {
                        elCallback.call( this, this.el[i], i );
                    }
                    for( var x = 0; x < fields.length; ++x ) {
                        if( typeof fieldCallback === 'function' ) {
                            fieldCallback.call( this, fields[x], i );
                        }
                    }
                }
            },

            /** @return void */
            onBlur: function( ev )
            {
                ev.target.parentNode.classList.remove( this.prefixed( 'has-focus' ));
            },

            /** @return void */
            onInput: function( ev )
            {
                ev.target.parentNode.classList[
                    this.addRemove( ev.target.value.length )
                ]( this.prefixed( 'is-active' ));
            },

            /** @return void */
            onFocus: function( ev )
            {
                ev.target.parentNode.classList.add( this.prefixed( 'has-focus' ));
            },

            /** @return void */
            onReset: function()
            {
                setTimeout( this.resetFields.bind( this ));
            },

            /** @return string */
            prefixed: function( value )
            {
                return this.config[this.current].prefix + value;
            },

            /** @return void */
            removeClasses: function( el )
            {
                var prefix = this.config[this.current].prefix;
                var classes = el.className.split( ' ' ).filter( function( c ) {
                    return c.lastIndexOf( prefix, 0 ) !== 0;
                });
                el.className = classes.join( ' ' ).trim();
            },

            /** @return null|void */
            reset: function( el )
            {
                var parent = el.parentNode;
                if( !this.hasParent( el ))return;
                var fragment = document.createDocumentFragment();
                while( parent.firstElementChild ) {
                    var childEl = parent.firstElementChild;
                    this.removeClasses( childEl );
                    fragment.appendChild( childEl );
                }
                parent.parentNode.replaceChild( fragment, parent );
                this.resetPlaceholder( el );
                this.handleEvents( el, 'remove' );
            },

            /** @return void */
            resetFields: function()
            {
                var fields = this.el[this.current].querySelectorAll( this.selectors[this.current] );
                for( var i = 0; i < fields.length; ++i ) {
                    fields[i].parentNode.classList[
                        this.addRemove( fields[i].tagName === 'SELECT' && fields[i].value !== '' )
                    ]( this.prefixed( 'is-active' ));
                }
            },

            /** @return void */
            resetPlaceholder: function( el )
            {
                var dataPlaceholder = 'data-placeholder';
                var originalPlaceholder = el.getAttribute( dataPlaceholder );
                if( originalPlaceholder !== null ) {
                    el.removeAttribute( dataPlaceholder );
                    el.setAttribute( 'placeholder', originalPlaceholder );
                }
            },

            /** @return void */
            setLabel: function( labelEl, el )
            {
                labelEl.classList.add( this.prefixed( 'label' ));
                labelEl.textContent = this.getLabelText( labelEl, el );
                if( typeof this.config[this.current].customLabel === 'function' ) {
                    labelEl.textContent = this.config[this.current].customLabel.call( this, labelEl, el );
                }
            },

            /** @return void */
            setPlaceholder: function( labelEl, el )
            {
                var placeholderText = el.getAttribute( 'placeholder' );
                if( this.config[this.current].prioritize === 'label' || !placeholderText ) {
                    if( placeholderText ) {
                        el.setAttribute( 'data-placeholder', placeholderText );
                    }
                    placeholderText = this.getLabelText( labelEl, el );
                }
                if( typeof this.config[this.current].customPlaceholder === 'function' ) {
                    placeholderText = this.config[this.current].customPlaceholder.call( this, placeholderText, el, labelEl );
                }
                if( el.tagName === 'SELECT' ) {
                    this.setSelectPlaceholder( el, placeholderText );
                }
                else {
                    el.setAttribute( 'placeholder', placeholderText );
                }
            },

            /** @return void */
            setSelectPlaceholder: function( el, placeholderText )
            {
                var childEl = el.firstElementChild;
                if( childEl.hasAttribute( 'value' ) && childEl.value ) {
                    var selected = el.options[el.selectedIndex].defaultSelected !== true ? true : false;
                    el.insertBefore( new Option( placeholderText, '', selected, selected ), childEl );
                }
                else {
                    childEl.setAttribute( 'value', '' );
                }
                if( childEl.textContent === '' ) {
                    childEl.textContent = placeholderText;
                }
            },

            /** @return void */
            wrapLabel: function( labelEl, el )
            {
                var wrapper = this.createEl( 'div', {
                    class: this.prefixed( 'wrap' ) + ' ' + this.prefixed( 'wrap-' + el.tagName.toLowerCase() ),
                });
                if( el.value !== undefined && el.value.length ) {
                    wrapper.classList.add( this.prefixed( 'is-active' ));
                }
                if( el.getAttribute( 'required' ) !== null || el.classList.contains( this.config[this.current].requiredClass )) {
                    wrapper.classList.add( this.prefixed( 'is-required' ));
                }
                el.parentNode.insertBefore( wrapper, el );
                wrapper.appendChild( labelEl );
                wrapper.appendChild( el );
            },
        };

        window.FloatLabels = Plugin;

    })( window, document );
  

JS /的script.js

    var floatlabels;
    var toggleBtn = document.querySelector( '.fl-toggle' );
    var styles = document.getElementsByName( 'style' );

    var getStyle = function() {
        for( var i = 0; i < styles.length; ++i ) {
            if( styles[i].checked ) {
                return styles[i].value;
            }
        }
        return 0;
    };

    var changeStyle = function( form ) {
        form.className = form.className.replace( /fl-style-\d/g, 'fl-style-' + getStyle() );
    };

    toggleBtn.addEventListener( 'click', function() {
        if( document.querySelector( '.fl-form' )) {
            floatlabels.destroy();
        }
        else {
            floatlabels = new FloatLabels( '.form-1', {
                style: getStyle(),
            });
        }
    });

    [].forEach.call( styles, function( style ) {
        style.addEventListener( 'change', function( ev ) {
            changeStyle( ev.target.closest( 'form' ));
        });
    });

    toggleBtn.click();

答案 2 :(得分:0)

我感谢大家的帮助。我决定按照第二个回应的说明,然后我意识到我可以删除所提到的脚本部分,以&#34; document.querySelectorAll(...))&#34开头;同时保留以下部分:

new FloatLabels('.form-1', {
  style: 1
});

通过这样做,我将完整地保留CSS并简单地使用上面的脚本,并分别在默认,样式1和样式2的样式0,1和2之间交替。

再一次,我感谢大家的帮助!你们是 很棒