如何将文本编辑器嵌入框架--以Umeditor&CodeIgniter框架为例

转:http://blog.csdn.net/u013332865/article/details/52066211

最近接到一个给某私立贵族(小,初,高 12年只是学费近200W)学校做一个网站,时间紧迫,本来打算用wordpress,但是要求页面要重新设计,而我们的前端开发没有WP主题开发的经验,无疑需要额外的学习成本(主要是时间来不及),所以提出自己做一个CMS的系统。但是文章编辑这块需要文本编辑器的基本功能,那就只能用富文本编辑器了。再加上本菜鸡喜欢用CI框架,所以需要把富文本编辑器和框架相结合,以下内容以此背景展开。


事前准备:
    环境:mac系统+Apache+mysql(没用到)+php(废话)
    富文本编辑器:umeditor (ueditor的简化版,需要用到的文本编辑器的道友可以试一下,很推荐)
    GitHub地址:https://github.com/fex-team/umeditor

    codeigniter框架(简称CI框框)
    官网地址:http://codeigniter.org.cn/
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8


先来一张umeditor的文件结构吧: 
 
图一



将文本编辑器嵌入框架,其本质就是在框架内的view中引入编辑器的样式和JS,在controller中引入编辑器的相关PHP类。



引入JS&CSS: 
 
图二 
CSS: 
图二中public\umeditor\umeditor.css&umeditor.min.css即图一中umeditor\themes\default\css中的两个文件。前者为未压缩,后者未压缩版。 
public\umeditor\formbtn.css即图二umeditor\index.html中文件里面的一些样式。 
图二public\images文件夹即图一umeditor\themes\default\images 
图二public\js\umeditor\dialogs&third-party即图一umeditor\dialogs&third-party 
图二public\js\umeditor\umeditor.js&umeditor.config.js即图一umeditor\umeditor.js&umeditor.config.js(umeditor.js与umeditor.min.js 这里不再赘述) 
图二public\js\zh-cs.js即图一umeditor\lang\zh-cn\zh-cn.js(中文的语言包,或者应该说是提示信息中文包) 
jQuery.min.js 这里用的是v2.2.3 
下面是在view中的引入:


    <link href="<?php echo base_url(‘/public/css/umeditor/umeditor.css‘); ?>" type="text/css" rel="stylesheet">
    <script type="text/javascript" src="<?php echo base_url(‘/public/js/jquery.min.js‘); ?>"></script>
    <script type="text/javascript" charset="utf-8" src="<?php echo base_url(‘/public/js/umeditor/umeditor.js‘); ?>"></script>
    <script type="text/javascript" charset="utf-8" src="<?php echo base_url(‘/public/js/umeditor/umeditor.config.js‘); ?>"></script>
    <script type="text/javascript" src="<?php echo base_url(‘/public/js/umeditor/zh-cn.js‘); ?>"></script>
    <link rel="stylesheet" href="<?php echo base_url(‘/public/css/umeditor/formbtn.css‘); ?>">
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
引入相关PHP类:
在CI框架下的application\libraries中新建一个文件‘Umupload.php‘(我个人只是想用上传,所以变这么命名)
然后将图一中umeditor\php\Upload.class.php中的所以代码直接Copy至上一步新建的文件中。

处理上传:
这里本菜鸡直接在CI的默认控制器 welcome中写了两个function 分别加载编辑器视图和处理上传,如下:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
<?php
defined(‘BASEPATH‘) OR exit(‘No direct script access allowed‘);

class Welcome extends CI_Controller {

    public function index()
    {
        $this->load->view(‘umeditor.html‘);
    }

    public function umupload(){
        error_reporting( E_ERROR | E_WARNING );
        //上传配置
        $config = array(
            "savePath" => "upload/" ,             //存储文件夹 (感觉没啥用)
            "maxSize" => 1000 ,
            "allowFiles" => array( ".gif" , ".png" , ".jpg" , ".jpeg" , ".bmp" )
        );
        //上传文件目录
        $Path = "upload/";

        //背景保存在临时目录中
        $config[ "savePath" ] = $Path;

        $this->load->library(‘Umupload‘,array(‘fileField‘=>‘upfile‘, ‘config‘ => $config));
        $type = $_REQUEST[‘type‘];
        $callback=$_GET[‘callback‘];

        $info = $this->umupload->getFileInfo();
        /**
         * 返回数据
         */
        if($callback) {
            echo ‘<script>‘.$callback.‘(‘.json_encode($info).‘)</script>‘;
        } else {
            echo json_encode($info);
        }

    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41

其中public function umupload()的函数体就是图一umeditor\php\imageUp.php中的内容,并且做了相关修改。

至此,编辑器已经全部嵌入框架,但是还需修改一些代码片段才可以正式使用。


后期加工,以下修改均指CI框架中的修改:
修改JS:CI\public\js\umeditor.config.js 第139行附近修改为:
  • 1
  • 2
  • 3

        //图片上传配置区
        ,imageUrl:URL+"../../../index.php/welcome/umupload"             //图片上传提交地址
        ,imagePath:URL + "../../../"                     //图片修正地址,引用了fixedImagePath,如有特殊需求,可自行配置
        ,imageFieldName:"upfile"                   //图片数据的key,若此处修改,需要在后台对应文件修改对应参数
  • 1
  • 2
  • 3
  • 4
  • 5
    这里主要是修改路径,让JS可以找到控制器。出于仓促这里使用相对路径。

修改PHP:
    据上文所述,在welcome的控制器中 public function umupload()的函数体是copy而来,所以要修改一部分使之可以在CI中‘跑‘起来。修改之后的代码如上文所示,具体修改为:
    删除最开始的两行:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

    header("Content-Type:text/html;charset=utf-8");
    error_reporting( E_ERROR | E_WARNING );
  • 1
  • 2
  • 3

将原编辑器中的 17行


    $up = new Uploader( "upfile" , $config );
  • 1
  • 2

修改为:

$this->load->library(‘Umupload‘,array(‘fileField‘=>‘upfile‘, ‘config‘ => $config));
  • 1

因为此处通过加载library的方式引入编辑器的相关PHP类。并且library的构造函数只能传一个参数,因此做此修改。

第21行附近的

$info = $up->getFileInfo();
  • 1

修改为:

$info = $this->umupload->getFileInfo();
  • 1
  • 2

这里即调用library引入类的方法。

修改library文件: 
通上文所述,library的构造函数只能传一个参数所以作如下修改: 
第43行附近修改为:

    public function __construct( $param)
    {
        $this->fileField = $param[‘fileField‘];
        $this->config = $param[‘config‘];
        $this->stateInfo = $this->stateMap[ 0 ];
        $this->upFile( false );
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

至此,umeditor文本编辑器已经嵌入CI框架。 
本人测试试用成功。 
umeditor的使用方法就不再赘述了。

更新于2016.8.30 融合bug(与bootstrap的CSS冲突)

如果使用bootstrap前端框架。那么umeditor编辑器中的图片在调整大小的时候会有一些”失灵”的BUG。 
主要是因为,编辑器的样式与bootstrap.css 的box-sizing设置有冲突

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
  • 1
  • 2
  • 3
  • 4
  • 5

解决方案: 
可以在用到编辑器的页面,重新设置包含编辑器的元素的该项属性

.edui-container *{
    -webkit-box-sizing: initial;
    -moz-box-sizing: initial;
    box-sizing: initial;
}
/* .edui-container 为包含编辑器的元素*/
时间: 2024-10-09 21:12:40

如何将文本编辑器嵌入框架--以Umeditor&CodeIgniter框架为例的相关文章

**【ci框架】精通CodeIgniter框架

http://blog.csdn.net/yanhui_wei/article/details/25803945 一.大纲 [php] view plaincopy 1.codeigniter框架的授课内容安排 2.codeigniter框架的简介 |-----关于框架的概念 |-----使用CI框架的好处 |-----为什么选择CI框架 3.codeigniter框架的具体安装步骤 |-----官网下载:http://www.codeigniter.com/ |-----httpd.conf配

程序员最爱的的 9 款文本编辑器

这年头,几乎每个开发人员都很熟悉开源代码和代码编写工具的好处.GitHub 和 SourceForge 之类的开源代码库为那些在自行构建应用程序方面寻求帮助的人提供了宝贵资源. 1. ATPad   ATPad 为偏爱使用文本编辑器而非成熟 IDE 的开发人员而设计,它提供了选项卡式环境.行编号.书签.代码片段系统.无限制的撤销/重做及更多功能. 支持的操作系统:Windows 2. CodeMirror 基于 JavaScript 的 CodeMirror 可以将文本编辑器嵌入到 Web 浏览

PHP接入umeditor(百度富文本编辑器)

2015年6月28日 23:08:49 星期日 效果: 开搞;) 首先: 百度官网上下载 umeditor 简版的富文本编辑器(这里) 然后: 解压放到自己的项目中, 配置服务器, 保证能在浏览器端加载到js,css,image... 最后: 准备好上传图片的程序, 我这里是用PHP直接上传到了七牛上 html (在第24~32行, 初始化一些配置, 不用去修改umeditor.config.js了) 1 <!DOCTYPE HTML> 2 <html> 3 <head>

UMeditor百度富文本编辑器的使用

批量上传的图片在线管理没法查看图片 是因为jar包本身的Bug,这里暂时做了个替换展示.就是找到Img.js  然后搜索 img.set 替换下就好了 var url=list[i].url ; url=url.replace("D:/JavaWorkSpace/.metadata/.me_tcat7/webapps/WebEUEdit",""); //img.setAttribute('src', urlPrefix + list[i].url + (list[i

使用百度UMeditor富文本编辑器,修改自定义图片上传,修改源码

富文本编辑器,不多说了,这个大家应该都用到过,至于用到的什么版本,那就分很多种 CKEditor:很早以前叫FCK,那个时候也用过,现在改名了,比较流行的一个插件,国外很多公司在用 UEDITOR:百度开发的插件,lite版是UM EasyUI编辑器:用easyUI的都懂,基本上肯定用到 其他的富文本编辑器就不说了,前两个小编我用的比较多 本来我是比较倾向于CKEditor,但是这个插件不支持图片上传,图片功能只能链接过去,而不能在控件本身中上传,所以就选择了UMeditor 为啥选择UM,不选

百度UMeditor富文本编辑器java使用

百度UMeditor富文本编辑器java使用 1.介绍 UMeditor 是一款轻量级的富文本编辑器,比UEditor要小得多,是为满足广大门户网站对于简单发帖框,或者回复框需求所定制的在线富文本编辑器 2.下载    官网地址:http://ueditor.baidu.com/website/umeditor.html 说明笔者点击官网的下载中的按钮,半天没反应,然后又去了github上down了一份,github地址:https://github.com/fex-team/umeditor/

百度 迷你版 UMeditor富文本编辑器 使用方法

第一步:下载编辑器 到官网下载 umeditor 最新版源码版本,下载之后打开 _examples/index.html 就可以看到演示例子.[下载页面] 第二步:部署编辑器到页面 解压下载的包,放到你的项目中. 在你的页面要插入编辑器的位置,插入代码: <!-- 加载编辑器的容器 --> <script id="container" name="content" type="text/plain" style="wi

富文本编辑器和fastdfs的使用

宜立方商城的系统架构a) 功能介绍(项目架构,有哪些功能模块,这些功能模块如何实现?)b) 架构讲解工程搭建-后台工程c) 使用maven搭建工程(后台工程如何搭建?)d) 使用maven的tomcat插件启动工程SSM框架整合. 服务中间件dubbo,使用dubbo实现soa架构.项目改造为基于SOA架构(什么是SOA架构,有什么好处,如何使用),面向服务的架构 图片上传功能分析,图片服务器,如何保存图片,如何访问图片?nginx的安装:反向代理服务器.Nginx配置虚拟机,Nginx实现反向

php如何引入百度Ueditor富文本编辑器

文本编辑器插件内容丰富,比起传统的textarea标签输入要好用很多,看看如何在页面实现引入吧 1.下载适合的资源包(可以去官网下载适合的版本),我是php引入 2.下载后解压放到一个位置.(我用的是TP框架,所以我放在了我的指定公共文件夹Pbulic下) 3.在页面中引入 首先在head标签里写引入资源包的路径,路径要写自己存放资源包的路径 <script type="text/javascript" src="__PUBLIC__/ueditor/ueditor.c