Heim >Backend-Entwicklung >PHP-Tutorial >Verwendung des Online-Editors CKeditor

Verwendung des Online-Editors CKeditor

不言
不言Original
2018-03-29 14:23:456549Durchsuche

本篇文章向大家介绍了PHP下CKeditor在线编辑器的使用,感兴趣的小伙伴们可以参考一下本篇文章。

CKeditor是一款在线编辑器,可用于博客、新闻发布等的文本编辑框,利用它可以很方便地实现对文章的排版。它是一款开源工具,可以在我们的网站中使用它增强编辑功能,显得专业和装B。原来它叫FCKeditor,后来改名叫CKeiditor,感谢开源软件的开发者,他们是最帅的!

一、下载

官网下载:http://ckeditor.com/download/

解压之后直接放在网站根目录里就可以使用了。

在_samples目录下,可以找到很多做好的样例,这些可以用来学习编辑器的用法。

二、用js的方式调用

官方演示样例:

100db36a723c770d327fc0aef2ce13b193f0f5c25f18dab9d176bd4f6de5d30e
    b2386ffb911b14667cb8f0f91ea547a7Sample CKEditor Site6e916e0f7d1e588d4f442bf645aedb2f
    2d18425269525fae6bd15347142b04472cacc6d41bbb37262a98f745aa00fbf09c3bca370b5104690d9ef395f2c5f8d16c04bd5ca3fcae76e30b72ad730ca86d
    362a264b75f4879ee0248ff8aec7f9a8
        e388a4556c0f65e1904146cc1a846bee
            My Editor:ff9d32c555bb1d9133a29eb4371c1213
            83ee1af48d65e781adc0507eafc447ef<p>Initial value.</p>40587128eee8df8f03d0b607fe983014
            8019067d09615e43c7904885b5246f0a
                CKEDITOR.replace( 'editor1' );            2cacc6d41bbb37262a98f745aa00fbf0
        94b3e26ee717c64999d7867364b1b4a3
        e388a4556c0f65e1904146cc1a846bee
            d459aba0527baf7434d808ac6f02b14f
        94b3e26ee717c64999d7867364b1b4a3
    f5a47148e367a6035fd7a2faa965022e36cc49f0c466276486e50c850b7e495673a6ac4ed44ffec12cee46588e518a5e

我是把ckeditor目录和test.html放在同个目录下,注意第四行原来是src="/ckeditor/ckeditor.js",要把前面的斜杠去掉,改为src="ckeditor/ckeditor.js"才能正确指向文件ckeditor.js。这时候不启用wamp服务器也能正确显示ckeditor。

三、用PHP的方法引入

e388a4556c0f65e1904146cc1a846beeTitle:94b3e26ee717c64999d7867364b1b4a3116230e109e9ee8a1a364fb2b7c613b1

6832ecefeb2613418b75c091f6348b61editor('content');?>

9ea2a188514dd40767484158c8dc8794

这样也能引入ckeditor,这时候editor的位置就在中间那段php代码的地方,两种方法都可以,不过我还不明白两种方法有什么区别。

还可以在textarea标签中嵌入ckeditor:

b0f07ee338ed63be67700654b706bfec";
    echo $_POST["content"];
}?>100db36a723c770d327fc0aef2ce13b193f0f5c25f18dab9d176bd4f6de5d30e
    b2386ffb911b14667cb8f0f91ea547a7Sample CKEditor Site6e916e0f7d1e588d4f442bf645aedb2f9c3bca370b5104690d9ef395f2c5f8d16c04bd5ca3fcae76e30b72ad730ca86d
    362a264b75f4879ee0248ff8aec7f9a8
        e388a4556c0f65e1904146cc1a846bee
            My Editor:ff9d32c555bb1d9133a29eb4371c1213
            9d4b1097ff533c07e208dfc2f023aaa5
            4b93b57b97adf0490fddc2e51bf7be28
            9da03fed5a48145d55d453a4ea4948c8editor('content');    
            ?>
            40587128eee8df8f03d0b607fe983014
        94b3e26ee717c64999d7867364b1b4a3
        e388a4556c0f65e1904146cc1a846bee
            c5c27b99ca0be180105976c2792b7f3e
        94b3e26ee717c64999d7867364b1b4a3
    f5a47148e367a6035fd7a2faa965022e36cc49f0c466276486e50c850b7e495673a6ac4ed44ffec12cee46588e518a5e

不过这样做有点小问题,

刚刷新页面的时候编辑器里面会出现个小框框,略不爽,开始输入之后它会自动消失,改成这样子就不会了:

<?php 
if(!empty($_POST["sub"]))
{
    echo $_POST["title"];
    echo "<br>";
    echo $_POST["content"];
}?><html><head>
    <title>Sample CKEditor Site</title>
    <script type="text/javascript" src="ckeditor/ckeditor.js"></script>
    <script type="text/javascript">
    window.onload = function()
    {
        CKEDITOR.replace( &#39;content&#39; );     //content是textarea的名称
    };</script></head><body>
    <form method="post">
        <p>
            My Editor:<br />
            <input type="text" name="title">
            <textarea name="content"></textarea>
        </p>
        <p>
            <input type="submit" name="sub"/>
        </p>
    </form></body></html>

四、配置编辑器

本段摘自网上一片文章,已忘记了原来出处。

ckeditor的配置都集中在 ckeditor/config.js 文件中,下面是一些常用的配置参数:

// 界面语言,默认为 'en'
config.language = 'zh-cn';

// 设置宽高
config.width = 400;
config.height = 400;

// 编辑器样式,有三种:'kama'(默认)、'office2003'、'v2'
config.skin = 'v2';

// 背景颜色
config.uiColor = '#FFF';

// 工具栏(基础'Basic'、全能'Full'、自定义)plugins/toolbar/plugin.js
config.toolbar = 'Basic';
config.toolbar = 'Full';

这将配合:
config.toolbar_Full = [
['Source','-','Save','NewPage','Preview','-','Templates'],
['Cut','Copy','Paste','PasteText','PasteFromWord','-','Print', 'SpellChecker', 'Scayt'],
['Undo','Redo','-','Find','Replace','-','SelectAll','RemoveFormat'],
['Form', 'Checkbox', 'Radio', 'TextField', 'Textarea', 'Select', 'Button', 'ImageButton', 'HiddenField'],
'/',
['Bold','Italic','Underline','Strike','-','Subscript','Superscript'],
['NumberedList','BulletedList','-','Outdent','Indent','Blockquote'],
['JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock'],
['Link','Unlink','Anchor'],
['Image','Flash','Table','HorizontalRule','Smiley','SpecialChar','PageBreak'],
'/',
['Styles','Format','Font','FontSize'],
['TextColor','BGColor']
];

//工具栏是否可以被收缩
config.toolbarCanCollapse = true;

//工具栏的位置
config.toolbarLocation = 'top';//可选:bottom

//工具栏默认是否展开
config.toolbarStartupExpanded = true;

// 取消 “拖拽以改变尺寸”功能 plugins/resize/plugin.js
config.resize_enabled = false;

//改变大小的最大高度
config.resize_maxHeight = 3000;

//改变大小的最大宽度
config.resize_maxWidth = 3000;

//改变大小的最小高度
config.resize_minHeight = 250;

//改变大小的最小宽度
config.resize_minWidth = 750;

// 当提交包含有此编辑器的表单时,是否自动更新元素内的数据
config.autoUpdateElement = true;

// 设置是使用绝对目录还是相对目录,为空为相对目录
config.baseHref = ''

// 编辑器的z-index值
config.baseFloatZIndex = 10000;

//Tastenkombinationen festlegen
config.keyStrokes = [
[ CKEDITOR.ALT + 121 /*F10*/, 'toolbarFocus' ], //Fokus abrufen
[ CKEDITOR.ALT + 122 / *F11*/, 'elementsPathFocus' ], //Elementfokus

[ CKEDITOR.SHIFT + 121 /*F10*/, 'contextMenu' ], //Textmenü

[ CKEDITOR. STRG + 90 /*Z*/, 'rückgängig' ], //Rückgängig
[ CKEDITOR.CTRL + 89 /*Y*/, 'wiederholen' ], //Wiederholen
[ CKEDITOR.CTRL + CKEDITOR . SHIFT + 90 /*Z*/, 'redo' ], //

[ CKEDITOR.CTRL + 76 /*L*/, 'link' ], //Link

[ CKEDITOR .STRG + 66 /*B*/, 'bold' ], //bold
[ CKEDITOR.CTRL + 73 /*I*/, 'italic' ], //italic
[ CKEDITOR.CTRL + 85 /*U*/, 'underline' ], //Underline

[ CKEDITOR.ALT + 109 /*-*/, 'toolbarCollapse' ]
]

// Verknüpfung festlegen Tasten können mit den Browser-Tastenkombinationen „plugin/keyStrokes/Plugin.js“ in Konflikt geraten. ,
CKEDITOR.CTRL + 85 /*U*/
]

//Legen Sie den Hintergrundfarbwert des Elements in der Editor-Plugins/colorbutton/plugin.js
-Konfiguration fest. colorButton_backStyle = {

element : 'span',

styles : { 'background-color' : '#(color)' }
}

//Stellen Sie die Vordergrundfarbe ein Wert-Plugins/ colorbutton/plugin.js
config.colorButton_colors = '000,800000,8B4513,2F4F4F,008080,000080,4B0082,696969,B22222,A52A2A,DAA520,

006400,40E0D0, 0000CD, 800080,808080 ,F00, FF8C00,FFD700,008000,0FF,00F,EE82EE,

A9A9A9,FFA07A,FFA500,FFFF00,00FF00,AFEEEE,ADD8E6,DDA0DD,D3D3D3,FFF0F5,
FAEBD7,FFFFE0,F0FFF0 FF,F0F8FF,E6E6FA, FFF'

//Ob die Option „Andere Farben“ angezeigt werden soll, wenn eine Farbe ausgewählt wird. Plugins/colorbutton/plugin.js
config.colorButton_enableMore = false

//Vordergrundfarbstandard blockieren Werteinstellung Plugins/colorbutton/plugin.js
config.colorButton_foreStyle = {

element : 'span',

styles : { 'color' : '#(color)' }
} ;

//Fügen Sie hier die CSS-Dateien hinzu, die hinzugefügt werden müssen. Sie können relative Pfade und absolute Pfade zur Website verwenden
config.contentsCss = './contents.css';

/ / Textrichtung
config.contentsLangDirection = 'rtl'; //Von links nach rechts

//Wenn Sie die CKeditor-Konfigurationsdatei nicht konfigurieren möchten, lassen Sie sie einfach leer
CKEDITOR. replace( 'myfiled', { customConfig : './config.js' } );

//Hintergrundfarbe des Interface-Bearbeitungsfeldsplugins/dialog/plugin.js
config.dialog_backgroundCoverColor = '# fffefd'; //Kann als Referenz festgelegt werden

config.dialog_backgroundCoverColor = 'white' //Standard


//Der Wert für die Hintergrundopazität sollte zwischen 0,0 und 1,0 liegen 🎜>config.dialog_backgroundCoverOpacity = 0.5

//Die Adsorptionsabstandseinheit des Randes beim Verschieben oder Ändern des Elements: pixelplugins/dialog/plugin.js

config.dialog_magnetDistance = 20;

//Ob lokale Rechtschreibprüfung und Eingabeaufforderungen abgelehnt werden sollen. Die Standardeinstellung ist „Verweigern“. Derzeit unterstützen nur Firefox- und Safari-Plugins/wysiwygarea/plugin.js

config.disableNativeSpellChecker = true

//Tabelle ausführen Bearbeitungsfunktionen wie: Hinzufügen von Zeilen oder Spalten. Derzeit unterstützt nur Firefox Plugins/wysiwygarea /plugin.js

config.disableNativeTableHandles = true; //Der Standardwert ist nicht aktiviert

//Ob die Funktion aktiviert werden soll zum Ändern der Größe von Bildern und Tabellen config.disableObjectResizing = true;

config.disableObjectResizing = false //Die Standardeinstellung ist

//Legt den HTML-Dokumenttyp fest

config.docType = '

//Ob der Bearbeitungsbereich „plugins/editingblock/plugin.js“ gerendert werden soll

config.editingBlock = true;

//Die durch den Wagenrücklauf im Editor generierte Bezeichnung

config. enterMode = CKEDITOR.ENTER_P; //Optional: CKEDITOR.ENTER_BR oder CKEDITOR.ENTER_p

// Ob HTML-Entitäten für Ausgabe-Plugins/entities/plugin.js verwendet werden sollen

config.entities = true;

//Definieren Sie weitere Entitäten Anzeige in entsprechende HTML-Zeichen. Plugins/entities/plugin.js

config.entities_greek = true;

//Ob einige lateinische Zeichen in HTML konvertiert werden sollen. Plugins/entities/plugin.js

config.entities_latin = true;

//Ob einige Sonderzeichen in ASCII-Zeichen konvertiert werden sollen, z. B. „Das ist Chinesisch: Chinesisch.“ In „Das ist Chinesisch: Chinesisch“ konvertieren.

config.entities_processNumerical = false;

//Neue Komponente hinzufügen

config.extraPlugins = 'myplugin '; //Nur nicht standardmäßiges Beispiel

//Farbe bei Verwendung von Such-Plugins hervorheben /find/plugin.js

config.find_highlight = {
element : 'span',

styles : { 'background-color' : '#ff0', 'color' : '#00f' }

};

//Standardschriftartplugins/font/plugin.js

config .font_defaultLabel = 'Arial';

//Sie können beim Bearbeiten von Schriftarten häufig verwendete chinesische Zeichen zum Zeichensatz hinzufügen: Song, Kai, Hei usw.plugins/font/plugin.js
config.font_names = 'Arial;Times New Roman;Verdana ';

//Standardstil von Textplugins/font/plugin.js
config.font_style = {
element : 'span',
styles : { 'font-family' : '#(family )' },
overrides : [ { element : 'font', attributes : { 'face' : null } } ]
};

//Plugins für die Standardschriftgröße/ font/plugin.js
config.fontSize_defaultLabel = '12px';

//Optionale Schriftgröße beim Bearbeiten von Schriftartenplugins/font/plugin.js
config.fontSize_sizes ='8/8px;9 /9px ;10/10px;11/11px;12/12px;14/14px;16/16px;18/18px;20/20px;22/22px;24/24px;26/26px;28/28px;36/36px ;48 /48px;72/72px'

//Styleplugins/font/plugin.js wird beim Festlegen der Schriftgröße verwendet
config.fontSize_style = {
element : 'span',
Stile: { 'font-size': '#(size)' },
overrides: [ { element: 'font', attributes: { 'size': null } } ]
};

//Ob erzwungen werden soll, dass der kopierte Inhalt das Format „plugins/pastetext/plugin.js“ entfernt
config.forcePasteAsPlainText =false //Nicht entfernen

//Ob „&“ erzwungen werden soll ersetzen Sie „&“plugins/htmldataprocessor/plugin.js
config.forceSimpleAmpersand = false;

//Formatieren Sie das Adress-Tagplugins/format/plugin.js
config.format_address = { element : 'address', attributes: { class: 'styledAddress' } };

//Formatieren Sie das p-Tag automatisch : { class : 'normalp' } };

//Formatieren Sie das H1-Tag automatisch. contentTitle1' } };


//H2-Tags automatisch formatieren 🎜>

//H3-Tags automatisch formatieren: Plugins/format/plugin.js

config.format_h1 = { element: 'h3', attributes: { class: 'contentTitle3' } }; /H4-Tags-Plugins automatisch formatieren/format/plugin.js
config.format_h1 = { element : 'h4', attributes : { class : 'contentTitle4' } };

//H5-Tags-Plugins automatisch formatieren /format/plugin.js
config.format_h1 = { element : 'h5', attributes : { class : 'contentTitle5' } };

//H6-Tags automatisch formatierenplugins/format/plugin.js
config.format_h1 = { element: 'h6', attributes: { class: 'contentTitle6' } };

//Ja P-Tags werden automatisch formatiert. Plugins/format/plugin.js
config .format_p = { element : 'p', attributes : { class : 'normalPara' } };

// PRE-Tags automatisch formatieren Formatplugins/format/plugin.js
config.format_pre = { element : 'pre', attributes : { class : 'code' } };

//Tag-Namen durch Semikolons getrennt. Plugins/format/plugin.js in der Symbolleiste anzeigen
config.format_tags = 'p; h1;h2;h3;h4;h5;h6;pre;address;p';

//Ja Wenn Sie den vollständigen HTML-Bearbeitungsmodus verwenden, enthält der Quellcode Folgendes: 100db36a723c770d327fc0aef2ce13b1config.fullPage = false;

/ /Ob leere Zeichen im Absatz ignoriert werden sollen, werden die Zeichen dargestellt ""plugins/wysiwygarea/plugin.js
config.ignoreEmptyParagraph = true;

//Link im Bildattributfeld löschen Gibt an, ob die 3499910bf9dac5ae3c52d5ede7383485-Tags auf beiden Seiten gleichzeitig gelöscht werden sollen Plugins/image/plugin.js
config.image_removeLinkByEmptyURL = true;

//Eine Reihe von durch Kommas getrennten Tag-Namen, die in der unteren linken Ecke angezeigt werden. Hierarchische Verschachtelung in Plugins/menu/plugin.js.
config.menu_groups ='clipboard,form,tablecell,tablecellproperties,tablerow,tablecolumn,table,anker,link,image,flash,checkbox,radio,textfield,hiddenfield, imagebutton,button,select,textarea';

//Verzögerung beim Anzeigen des Untermenüs, Einheit: msplugins/menu/plugin.js
config.menu_subMenuDelay = 400;

/ /Beim Ausführen des Befehls „Neu“ wird der Inhalt im Editor angezeigt plugins/newpage/plugin.j s
config.newpage_html = '';

//Ob beim Kopieren von Text aus Word fortgefahren werden soll Formatentfernung von Textplugins/pastefromword/plugin.js
config. pasteFromWordIgnoreFontFace = true; //Standardmäßig wird das Format ignoriert

//Ob Tags wie 4a249f0d628e2318394fd9b75b4636b1c1a436a314ed609750bd7c7d319db4da verwendet werden sollen, um den aus dem Word-Dokument eingefügten Inhalt zu ändern oder zu ersetzen .js
config.pasteFromWordKeepsStructure = false;

//Ob das Format beim Einfügen von Inhalten aus Word-Plugins entfernt werden soll/pastefromword/plugin.js
config.pasteFromWordRemoveStyle = false;

//Formatieren Sie den ausgegebenen HTML-Inhalt entsprechend der Art der Hintergrundsprache, der Standardwert ist leer
config.protectedSource.push( /85c49297af5dc9e374874262c9f05092/ g ); // PHP-Code
config.protectedSource.push( //g ); // ASP-Code
config.protectedSource.push( /(]+>["s|"S]*?< ; "/asp:[^">]+>)|(]+"/>)/gi ); // ASP.Net-Code

//Bei Eingabe einfügen: Umschalt+Tag eingeben
config.shiftEnterMode = CKEDITOR.ENTER_P; //Optional: CKEDITOR.ENTER_BR oder CKEDITOR.ENTER_p

//Optionale Ausdrucksersetzungszeichen-Plugins/smiley/plugin.js.
config.smiley_descriptions = [
':)', ':(', ';)', ':D', ':/', ':P',
'', '', '', '', '', '',
'', ';(', '', '', '', '',
'', ':kiss', '' ];

//Entsprechend Emoticon-Bilder Plugins/smiley/plugin.js
config.smiley_images = [
'regular_smile.gif','sad_smile.gif','wink_smile.gif','teeth_smile.gif' ,'confused_smile.gif', 'tounge_smile.gif',
'embaressed_smile.gif','omg_smile.gif','whatchutalkingabout_smile.gif','angry_smile.gif','angel_smile.gif','shades_smile.gif ',
'devil_smile .gif','cry_smile.gif','lightbulb.gif','thumbs_down.gif','thumbs_up.gif','heart.gif',
'broken_heart.gif', 'kiss.gif',' Envelope.gif'];

//Die Adresse des Ausdrucksplugins/smiley/plugin.js
config.smiley_path = 'plugins/smiley/images/';

// Wenn die Seite geladen wird, wird angezeigt, ob das Bearbeitungsfeld sofort den Fokus erhält und WYSIWYG „source“ und „wysiwyg“plugins/editingblock/plugin.js
config.startupMode ='wysiwyg';

//Ob beim Laden die Frame-Rahmen-Plugins/showblocks/plugin angezeigt werden sollen .js
config.startupOutlineBlocks = false;

//ob die Stildatei geladen werden sollplugins/stylescombo/plugin.js
config.stylesCombo_stylesSet = 'default';

//Die Folgendes ist optional

config.stylesCombo_stylesSet = 'mystyles';
config.stylesCombo_stylesSet = 'mystyles:/editorstyles/styles.js';
config.stylesCombo_stylesSet = 'mystyles:http://www.example. com/editorstyles/styles.js';

//Startindexwert
config.tabIndex = 0;

// Wenn der Benutzer TAB eingibt, wird die Anzahl der von der übergebenen Leerzeichen angezeigt Editor, ( ) Wenn der Wert 0 ist, wird der Fokus aus dem Bearbeitungsfeld verschoben. Plugins/tab/plugin.js
config.tabSpaces = 0;

//Die standardmäßig verwendete Vorlage plugins/templates/plugin.js.
config.templates = 'default';

//Komma-getrennte Vorlagendateienplugins/templates/plugin.js.
config.templates_files = [ 'plugins /templates/templates/default.js' ]

//Ob bei der Verwendung von Vorlagen das Kontrollkästchen „Bearbeiteter Inhalt wird ersetzt“ aktiviert ist Plugins/templates/plugin.js
config.templates_replaceContent = true;

//Theme
config.theme = 'default';

//Aufzeichnungsschritte rückgängig machen plugins/undo/plugin.js
config.undoStackSize =20;

//CKFinder in CKEditor integrieren und auf die richtige Pfadauswahl von ckfinder achten.
//CKFinder.SetupCKEditor(null, '/ckfinder/')

Verwandte Empfehlungen:

Thinkphp Editor Extension Class Kindeditor Usage Method_PHP Tutorial

PHP-Editor

Das obige ist der detaillierte Inhalt vonVerwendung des Online-Editors CKeditor. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn