zoukankan      html  css  js  c++  java
  • yii2-Ueditor百度编辑器

    今天在网上看了下有关图片上传的教程,历经挫折才调试好,现在把相关代码及其说明贴出来,以供初次使用的朋友们参考。

    资源下载

    yii2.0-ueditor下载路径:

    
    https://link.jianshu.com?t=https://github.com/org-yii-china/yii2-ueditor/archive/master.zip
    

    效果演示:

    安装方法:

    1.下载yii2-ueditor
    2.将下载的yii2-ueditor-master 修改 ueditor (注意:修改成其他文件名请修改插件内对应的命名空间)
    3.将文件方在 根目录/common/widgets 下即可

    调用方法:

    在backend/controllers中新建一个控制器Demo加入以下代码

    
    public function actions(){
        return [
            'ueditor'=>[
                'class' => 'commonwidgetsueditorUeditorAction',
                'config'=>[
                    //上传图片配置
                    'imageUrlPrefix' => "", /* 图片访问路径前缀 */
                    'imagePathFormat' => "/image/{yyyy}{mm}{dd}/{time}{rand:6}", /* 上传保存路径,可以自定义保存路径和文件名格式 */
                ]
            ]
        ];
    }
    

    第一种调用方式:

    在对应的渲染页面,即views下的页面中

    
    <?=commonwidgetsueditorUeditor::widget(['options'=>['initialFrameWidth' => 850,]])?>
    

    options 填写配置编辑器的参数(参考ueditor官网)

    第二种调用方式:

    
    <?php $form = ActiveForm::begin(); ?>
    
    <?= $form->field($model, 'title')->textInput(['maxlength' => true]) ?>
    
    <?= $form->field($model, 'content')->widget('commonwidgetsueditorUeditor',[
        'options'=>[
            'initialFrameWidth' => 850,
        ]
    ]) ?>
    
      ...
    
    <?php ActiveForm::end(); ?>
    

    yii2框架整合了百度编辑器,因为文件上传采用的是yii2自带的UploadedFile,这就难免umeditor上传不成功问题,解决问题的只需要两个操作步骤,我们来看看具体实现

    创建一个 common/models/Upload.php:

    代码为:

    
    <?PHP
    namespace commonmodels;
    
    use yiiaseModel;
    use yiiwebUploadedFile;
    
    /**
     * UploadForm is the model behind the upload form.
     */
    class Upload extends Model
    {
        /**
         * @var UploadedFile file attribute
         */
        public $file;
    
        /**
         * @return array the validation rules.
         */
        public function rules()
        {
            return [
                [['file'], 'file'],
            ];
        }
    }
    

    需要在刚刚创建的那个控制器Demo里添加actionUploadImage方法处理“富文本框的图片上传”内容

    
    use yiiwebUploadedFile;
    use commonmodelsUpload;
    /**
         * 富文本框的图片上传
         * @return array
         */
        public function actionUploadImage()
        {
            $model = new Upload();
            if (Yii::$app->request->isPost) {
                $model->file = UploadedFile::getInstance($model, "file");
                $dir = '/uploads/ueditor/';//文件保存目录
                if (!is_dir($dir))
                    mkdir($dir);
                if ($model->validate()) {
                    $fileName = $model->file->baseName . "." . $model->file->extension;
                    $dir = $dir."/". $fileName;
                    $model->file->saveAs($dir);
                    $info = [
                        "originalName" => $model->file->baseName,
                        "name" => $model->file->baseName,
                        "url" => $dir,
                        "size" => $model->file->size,
                        "type" => $model->file->type,
                        "state" => "SUCCESS",
                    ];
                    exit(json_encode($info));
                }
            }
        }
    

    特别提醒:上述返回的$info信息中state状态只能是SUCCESS,区分大小写

    视图文件

    
    <?php
    use yiiwidgetsActiveForm;
    ?>
    
     <?= $form->field($model, 'content')->widget('commonwidgetsueditorUeditor',[
            'options'=>[
                'initialFrameWidth' => 1050,//宽度
                'initialFrameHeight' => 550,//高度
            ]
        ]) ?>
    <div class="form-group">
            <?= Html::submitButton('保存', ['class' => 'btn btn-success']) ?>
        </div>
    
    <?php ActiveForm::end() ?>
    

    其中content是字段名称

    关于图片上传的可以看下:

    
    https://www.yiichina.com/tutorial/862
    

    在YII2框架中使用UEditor编辑器发布文章的地址:

    
    https://www.cnblogs.com/felixji/p/6698436.html
    

    原文地址:https://segmentfault.com/a/1190000016878464

  • 相关阅读:
    hiho 103 平衡树·Treap
    HDU 5738 Eureka
    codeforces 682D Alyona and Strings
    Photoshop cs5 永久序列号
    httpd.exe你的电脑中缺失msvcr110.dll怎么办
    Gzip压缩启用图文方法详细说明
    帝国CMS开启全站搜索功能
    怎么给电脑统一设置查看文件为列表形式?
    帝国CMS网站地图sitemap的制作教程,分享2种帝国cms网站地图模板
    lol安装包打开没反应
  • 原文地址:https://www.cnblogs.com/lalalagq/p/9964038.html
Copyright © 2011-2022 走看看