How to make TinyMCE Responsive

后端 未结 6 1889
抹茶落季
抹茶落季 2020-12-28 17:18

I am making a Responsive site using the foundation framework and TinyMCE breaks the format when the page is scaled down(it\'s not responsive). How do I make TinyMCE responsi

相关标签:
6条回答
  • 2020-12-28 17:49

    There is a way to get the toolbars to wrap on smaller screens.

    /* make the toolbar wrap */
    .mceToolbar td {
        display:table-row;
        float: left;
    }
    .mceToolbar td:nth-of-type(11){
        clear: left;
    }
    

    I made a fork of the fiddle that Johannes posted that includes the above rules:

    http://jsfiddle.net/joshfeck/gMVSE/

    0 讨论(0)
  • 2020-12-28 17:49

    Making the toolbar responsive for the latest version of TinyMCE:

    .tox-toolbar {
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
    }
    .tox-toolbar__group {
        flex-wrap: nowrap !important;
    }
    

    This adds a horizontal scrollbar to the toolbar on mobile devices.

    0 讨论(0)
  • 2020-12-28 17:51

    TinyMCE 5.1 was released with a new mobile responsive design.

    To ensure it functions as intended, you need to add the following code to the head of your pages that are using TinyMCE.

    <meta name="viewport" content="width=device-width, initial-scale=1">
    

    More information here: https://www.tiny.cloud/blog/the-future-of-work-is-mobile-and-tiny-is-ready-for-it

    0 讨论(0)
  • 2020-12-28 17:55

    I'm using version 4 of TinyMCE, there is a plugin named autoresize. It makes the editor responsive.

    0 讨论(0)
  • 2020-12-28 18:03

    The TinyMCE editor can be made responsive by using css media queries. Simply add css rules that set the width property of table.mceLayout and the tinyMCE textareas. You will need to enforce these css rules using !important because they would otherwise be overwritten.

    E.g., I use css similar to this:

    /* on mobile browsers, I set a width of 100% */
    table.mceLayout, textarea.tinyMCE {
        width: 100% !important;
    }
    
    /* on large screens, I use a different layout, so 600px are sufficient */
    @media only screen and (min-width: 600px) {
        table.mceLayout, textarea.richEditor {
           width: 600px !important;
        }
    }
    

    See this jsfiddle: http://jsfiddle.net/johannesjh/384uf/

    Note: You may wish to use different media queries or css classes to make use to the "foundation framework"'s responsive grid.

    0 讨论(0)
  • 2020-12-28 18:03

    Here is something I use on a site to make the editor resize and the toolbars moves with the size of the page :

    .mceEditor table {
    max-width:none; /* Bug in computation of fullscreen */
    }
    
    .mceEditor table.mceLayout {
    width:100% !important;
    height:auto !important;
    } 
    
    table.mceToolbar { float:left; }
    body .mceToolbar div {
    white-space:normal;
    }
    

    Using small toolbar, they are properly layed out as the editor width changes. "theme_advanced_resizing" should be set to "false". Also, more work is needed to make it work with fullscreen.

    0 讨论(0)
提交回复
热议问题