Компонент Material Design и поля ввода reactjs

Итак, у меня есть MDC, наконец, работающий с React, и с помощью документов Google я понял, что мне нужно, чтобы reactjs запускал следующий JS, когда пользователь нажимает на поле ввода - в основном метка должна перемещаться над вводом, чтобы пользователь мог ввести - как моя демонстрация на чистом HTML/JS https://codepen.io/russellharrower/pen/oeReEN

Однако с помощью reactjs я заметил, что не могу поместить код ниже в область рендеринга, поэтому мне интересно, где бы я его разместил и как?

(function() {
        var tfs = document.querySelectorAll(
          '.mdc-textfield:not([data-demo-no-auto-js])'
        );
        for (var i = 0, tf; tf = tfs[i]; i++) {
          mdc.textfield.MDCTextfield.attachTo(tf);
        }
      })();

полный код reactjs обновлен

import React, { Component } from 'react';
import './App.css';
import * as mdc from 'material-components-web';

class App extends Component {
    hrefjs(l){
            var script   = document.createElement("script");
            script.type  = "text/javascript";
            script.src   = l;    // use this for linked script
            document.body.appendChild(script);
    }


    componentWillMount() {
            this.hrefjs("//unpkg.com/material-components-web@latest/dist/material-components-web.min.js");
            var texst ="(function(){var tfs = document.querySelectorAll('.mdc-textfield:not([data-demo-no-auto-js])'); for (var i = 0, tf; tf = tfs[i]; i++) {mdc.textfield.MDCTextfield.attachTo(tf); mdc.autoInit();}})();"
            const script = document.createElement("script");
            script.text=texst;
            document.body.appendChild(script);
    };
  render() {
    return (
      <div className="App">
        <header className="mdc-toolbar mdc-toolbar--fixed mdc-toolbar--waterfall">
          <div className="mdc-toolbar__row">
            <section className="mdc-toolbar__section mdc-toolbar__section--align-start">
              <span className="mdc-toolbar__title">Title</span>
            </section>
          </div>
        </header>
        <main className="demo-main mdc-toolbar-fixed-adjust">

            <div className="mdc-form-field">
              <div className="mdc-checkbox">
                <input type="checkbox"
                       id="my-checkbox"
                       className="mdc-checkbox__native-control"/>
                <div className="mdc-checkbox__background">
                  <svg className="mdc-checkbox__checkmark"
                       viewBox="0 0 24 24">
                    <path className="mdc-checkbox__checkmark__path"
                          fill="none"
                          stroke="white"
                          d="M1.73,12.91 8.1,19.28 22.79,4.59"/>
                  </svg>
                  <div className="mdc-checkbox__mixedmark"></div>
                </div>
              </div>
              <label htmlhtmlhtmlFor="my-checkbox" id="my-checkbox-label">This is my checkbox</label>
            </div>
            <section className="example">
                 <div className="mdc-textfield">
                      <input type="text" id="username" className="mdc-textfield__input" aria-controls="username-helptext"/>
                      <label htmlFor="username" className="mdc-textfield__label">Username</label>
                    </div>
                    <p id="username-helptext" className="mdc-textfield-helptext" aria-hidden="true">
                      This will be displayed on your public profile
                    </p>
              </section>
        </main>
        <script>
        mdc.toolbar.MDCToolbar.attachTo(document.querySelector('.mdc-toolbar'));
        //mdc.textfield.MDCToolbar.attachTo(document.querySelector('.mdc-textfield'));
        //mdc.autoInit();
        </script>

        </div>
    );
  }
}

export default App;

Последнее обновление Я добавил эти две функции, однако по какой-то причине (function(){})(); script, пока он будет делать предупреждение и т. д., он не позволит текстовой метке перемещаться, как в демонстрации codepen.io

hrefjs(l){
        var script   = document.createElement("script");
        script.type  = "text/javascript";
        script.src   = l;    // use this for linked script
        document.body.appendChild(script);
}


componentWillMount() {
        this.hrefjs("//unpkg.com/material-components-web@latest/dist/material-components-web.min.js");
        var texst ="(function(){var tfs = document.querySelectorAll('.mdc-textfield:not([data-demo-no-auto-js])'); for (var i = 0, tf; tf = tfs[i]; i++) {mdc.textfield.MDCTextfield.attachTo(tf); mdc.autoInit();}})();"
        const script = document.createElement("script");
        script.text=texst;
        document.body.appendChild(script);
};

person RussellHarrower    schedule 06.09.2017    source источник
comment
вы можете добавить код javascript в свой componentDidMount. Он будет запущен после рендеринга компонента   -  person bennygenel    schedule 06.09.2017
comment
спасибо, я добавил часть componentWillMount в любое время, пока скрипт работает, похоже, ему не нравится тот факт, что мы добавляем скрипт. их нет, чтобы сначала загрузить?   -  person RussellHarrower    schedule 07.09.2017
comment
я смог заставить его работать, сделав его функцией onClick, но я уверен, что это не то, что имел в виду Google?   -  person RussellHarrower    schedule 07.09.2017


Ответы (1)


Даже если ваш подход в итоге как-то сработает. На самом деле это не очень приятный способ продолжать разработку, и ваш код станет кошмаром для других (или для вас самих). На самом деле это можно сделать намного проще. Обычно я пишу обертки react.js для нужных мне компонентов из MDC. Вот пример для текстового поля:

import React from 'react';
import { MDCRipple } from '@material/ripple/dist/mdc.ripple';

class MdcButton extends React.Component {
    constructor(props) {
        super(props);
        // Init state
        this.state = {}
    }

    componentDidMount() {
        if (this.props.ripple)
            MDCRipple.attachTo(this.refs.button);
    }

    static defaultProps = {
        ripple: true,
        raised: true,
        disabled: false,
        className: "",
        type: "submit"
    }

    render() {
        let className = "mdc-button " + this.props.className;
        if (this.props.raised)
            className += " mdc-button--raised";

        return (
            <button
                ref="button"
                id={this.props.id}
                className={className}
                type={this.props.type}
                onClick={this.props.onClick}
                disabled={this.props.disabled}
            >
                {this.props.children}
            </button>
        );
    }
}

export default MdcButton

Вы можете посмотреть официальную демонстрацию mdc для react.js здесь (https://github.com/material-components/material-components-web/tree/master/framework-examples/react).

Для стилизации я включаю файлы mdc sccs в свои файлы scss и меняю нужные мне значения. например.:

$mdc-theme-primary: #404040;
$mdc-theme-accent: #a349a3;
$mdc-theme-background: #fff;  

@import "@material/ripple/mdc-ripple";
@import "@material/typography/mdc-typography";
@import "@material/theme/mdc-theme";
@import "@material/button/mdc-button";
person Jodo    schedule 11.10.2017