中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

使用JavaScript為Kindeditor自定義按鈕增加Audio標簽
來源:易賢網 閱讀:1943 次 日期:2016-07-19 14:57:26
溫馨提示:易賢網小編為您整理了“使用JavaScript為Kindeditor自定義按鈕增加Audio標簽”,方便廣大網友查閱!

這篇文章主要介紹了使用JavaScript為Kindeditor自定義按鈕增加Audio標簽的方法,KindEditor是一套開源的HTML可視化編輯器,需要的朋友可以參考下

流程比較簡單,主要有以下步驟:

注冊插件(按鈕、Lang、htmlTags、插件腳本)

基于media插件代碼修改

注冊插件

首先,全局配置kindeditor參數:

KindEditor.lang({

 audio : 'MP3'

});

 KindEditor.options.htmlTags['audio'] = ['src','controls','autoplay','type'];

 KindEditor.options.htmlTags['source'] = ['src','controls','autoplay','type'];

在初始化編輯器的地方,配置按鈕列表items參數,把

'audio'

放在合適的位置:

KindEditor.ready(function(K) {

editor = K.create('#info,#spread_info', {

  //其他配置省略...

  items : [

    'source', '|', 'undo', 'redo', '|', 'preview', 'print', 'template', 'code', 'cut', 'copy', 'paste',

    'plainpaste', 'wordpaste', '|', 'justifyleft', 'justifycenter', 'justifyright',

    'justifyfull', 'insertorderedlist', 'insertunorderedlist', 'indent', 'outdent', 'subscript',

    'superscript', 'clearhtml', 'quickformat', 'selectall', '|', 'fullscreen', '/',

    'formatblock', 'fontname', 'fontsize', '|', 'forecolor', 'hilitecolor', 'bold',

    'italic', 'underline', 'strikethrough', 'lineheight', 'removeformat', '|', 'image', 'multiimage',

     '|' ,'table', 'hr', 'emoticons', 'baidumap', 'pagebreak',

    'anchor', 'link', 'unlink', '|', 'about','audio'

  ]

});

為了便于閱讀,我把audio按鈕放在最后,在 "幫助" 標簽的后面。

為了讓按鈕能夠顯示,我們還需要指定一下css樣式:

<style>

  .ke-icon-audio {

    background-position: 0px -528px;

    width: 16px;

    height: 16px;

  }

</style>

這里我圖方便,直接用了自帶的音視頻按鈕的圖標,自定義圖標請手動指定 background 樣式屬性。

最后,創建腳本

kindeditor/plugins/audio/audio.js

audio目錄手動建立。

我們把

plugins/media/media.js

中的代碼復制到audio.js里,然后著手修改。

修改media插件

主要是去掉一些無用的屬性,如 寬、高、自動播放等,并修改插入代碼的部分,手動構建 "audio" 標簽的html代碼。

/**

 * Created by admin on 15-5-6.

 */

KindEditor.plugin('audio', function(K) {

  var self = this, name = 'audio', lang = self.lang(name + '.'),

    allowMediaUpload = K.undef(self.allowMediaUpload, true),

    allowFileManager = K.undef(self.allowFileManager, false),

    formatUploadUrl = K.undef(self.formatUploadUrl, true),

    uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php');

  self.plugin.media = {

    edit : function() {

      var html = [

        '<div style="padding:20px;">',

        //url

        '<div class="ke-dialog-row">',

        '<label for="keUrl" style="width:60px;">MP3 URL</label>',

        '<input class="ke-input-text" type="text" id="keUrl" name="url" value="" style="width:160px;" />  ',

        '<input type="button" class="ke-upload-button" value="上傳" />  ',

        '</div>',

        '</div>'

      ].join('');

      var dialog = self.createDialog({

          name : name,

          width : 450,

          height : 230,

          title : self.lang(name),

          body : html,

          yesBtn : {

            name : self.lang('yes'),

            click : function(e) {

              var url = K.trim(urlBox.val()),

                width = widthBox.val(),

                height = heightBox.val();

              if (url == 'http://' || K.invalidUrl(url)) {

                alert(self.lang('invalidUrl'));

                urlBox[0].focus();

                return;

              }

              if (!/^\d*$/.test(width)) {

                alert(self.lang('invalidWidth'));

                widthBox[0].focus();

                return;

              }

              if (!/^\d*$/.test(height)) {

                alert(self.lang('invalidHeight'));

                heightBox[0].focus();

                return;

              }

              var html = '<p><audio src="'+url+'" controls="controls"></audio><br/></p>';

              self.insertHtml(html).hideDialog().focus();

            }

          }

        }),

        div = dialog.div,

        urlBox = K('[name="url"]', div),

        viewServerBtn = K('[name="viewServer"]', div),

        widthBox = K('[name="width"]', div),

        heightBox = K('[name="height"]', div),

        autostartBox = K('[name="autostart"]', div);

      urlBox.val('http://');

      if (allowMediaUpload) {

        var uploadbutton = K.uploadbutton({

          button : K('.ke-upload-button', div)[0],

          fieldName : 'imgFile',

          url : K.addParam(uploadJson, 'dir=audio'),

          afterUpload : function(data) {

            dialog.hideLoading();

            if (data.error === 0) {

              var url = data.url;

              if (formatUploadUrl) {

                url = K.formatUrl(url, 'absolute');

              }

              urlBox.val(url);

              if (self.afterUpload) {

                self.afterUpload.call(self, url);

              }

              alert(self.lang('uploadSuccess'));

            } else {

              alert(data.message);

            }

          },

          afterError : function(html) {

            dialog.hideLoading();

            self.errorDialog(html);

          }

        });

        uploadbutton.fileBox.change(function(e) {

          dialog.showLoading(self.lang('uploadLoading'));

          uploadbutton.submit();

        });

      } else {

        K('.ke-upload-button', div).hide();

      }

      if (allowFileManager) {

        viewServerBtn.click(function(e) {

          self.loadPlugin('filemanager', function() {

            self.plugin.filemanagerDialog({

              viewType : 'LIST',

              dirName : 'media',

              clickFn : function(url, title) {

                if (self.dialogs.length > 1) {

                  K('[name="url"]', div).val(url);

                  self.hideDialog();

                }

              }

            });

          });

        });

      } else {

        viewServerBtn.hide();

      }

      var img = self.plugin.getSelectedMedia();

      if (img) {

        var attrs = K.mediaAttrs(img.attr('data-ke-tag'));

        urlBox.val(attrs.src);

        widthBox.val(K.removeUnit(img.css('width')) || attrs.width || 0);

        heightBox.val(K.removeUnit(img.css('height')) || attrs.height || 0);

        autostartBox[0].checked = (attrs.autostart === 'true');

      }

      urlBox[0].focus();

      urlBox[0].select();

    },

    'delete' : function() {

      self.plugin.getSelectedMedia().remove();

    }

  };

  self.clickToolbar(name, self.plugin.media.edit);

});

至此,整個插件基本結束。

需要注意的是,上傳文件用的是通用的配置uploadJson參數,但會在上傳的時候自動添加一個get參數 "dir=audio" ,以便后臺識別:

url : K.addParam(uploadJson, 'dir=audio'),

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
不卡的电影网站| 久久综合狠狠综合久久综合88| 欧美日韩久久久| 最好看的中文字幕久久| 99精品国产91久久久久久| 中文字幕国产一区| 99视频超级精品| 亚洲一区二区三区四区不卡| 欧美日韩精品一区二区在线播放| 亚洲乱码日产精品bd| 欧美精品九九99久久| 蜜臀久久99精品久久久久久9| 911精品产国品一二三产区| 国产精品动漫网站| 国产不卡视频在线观看| 亚洲免费av高清| 日韩视频免费观看高清完整版| 国产69精品久久99不卡| 一个色综合网站| 精品电影一区二区| 成人性生交大合| 久久国产夜色精品鲁鲁99| 亚洲精品国产成人久久av盗摄| 欧美一区二区在线看| 一本到三区不卡视频| 国产专区综合网| 日本美女一区二区三区| 最新欧美精品一区二区三区| xfplay精品久久| 精品日韩在线观看| 一本大道久久a久久精二百| 国产一区二区在线免费观看| 日韩影视精彩在线| 亚洲第一电影网| 又紧又大又爽精品一区二区| 欧美国产禁国产网站cc| 日本一二三四高清不卡| 久久嫩草精品久久久精品| www.爱久久.com| 裸体一区二区三区| 久久66热re国产| 麻豆精品国产传媒mv男同| 美美哒免费高清在线观看视频一区二区 | 亚洲欧美在线aaa| 国产精品久久午夜夜伦鲁鲁| 国产精品久久久久久一区二区三区 | 91精品婷婷国产综合久久性色| 色婷婷一区二区三区四区| 91久久久免费一区二区| 91亚洲国产成人精品一区二区三 | 精品国精品国产| 精品福利二区三区| 国产精品第13页| 亚洲成人你懂的| 国产在线播放一区二区三区| 国产91对白在线观看九色| 成人一区二区三区| 国产大陆亚洲精品国产| 色综合激情五月| 制服丝袜亚洲网站| 久久亚洲捆绑美女| 尤物视频一区二区| 国产一区二区精品久久99| bt7086福利一区国产| av成人动漫在线观看| 欧美人妇做爰xxxⅹ性高电影| 国产日韩欧美激情| 一区二区三区成人| 成人黄色a**站在线观看| 欧美日本免费一区二区三区| 中文字幕一区视频| 国产精品一区免费视频| 欧美一区二区三区日韩视频| 国产精品日韩成人| 另类小说综合欧美亚洲| 欧美日韩一区二区三区不卡| 中文字幕在线免费不卡| 国产99久久久国产精品潘金网站| 日韩欧美在线一区二区三区| 午夜精品久久久久久久久久久 | 91麻豆精品久久久久蜜臀| 欧美一区二区三区免费| 五月天一区二区三区| 欧美日韩一区二区三区高清| 亚洲人亚洲人成电影网站色| 暴力调教一区二区三区| 国产亚洲精品免费| 成人听书哪个软件好| 国产精品欧美一区喷水| 成人高清在线视频| 亚洲精品ww久久久久久p站| 色播五月激情综合网| 亚洲高清视频的网址| 日韩欧美电影在线| 处破女av一区二区| 亚洲不卡一区二区三区| 日韩三级电影网址| 国产乱码精品一区二区三区av| 久久免费偷拍视频| 在线观看亚洲专区| 国产成a人亚洲| 亚洲国产cao| 亚洲色图色小说| 欧美一区二区三区不卡| 色综合久久九月婷婷色综合| 老司机精品视频导航| 最新久久zyz资源站| 日韩三级.com| 91在线观看下载| 亚洲综合色噜噜狠狠| 日韩视频在线一区二区| 色诱视频网站一区| 国产黄色精品网站| 久久9热精品视频| 亚洲高清在线精品| 亚洲男人的天堂一区二区| 久久久久久久久久久久久夜| 88在线观看91蜜桃国自产| 91丨九色丨蝌蚪富婆spa| 久久er99热精品一区二区| 五月婷婷激情综合网| 亚洲在线观看免费视频| 亚洲国产精品成人综合色在线婷婷 | 日本国产一区二区| 91日韩在线专区| 色哟哟一区二区在线观看| 99久久婷婷国产综合精品| 成人做爰69片免费看网站| 91麻豆精品秘密| 欧美三级日韩在线| 91精品国产入口| 26uuu久久天堂性欧美| 欧美xxx久久| 国产精品国产三级国产三级人妇| 日韩毛片视频在线看| 亚洲黄色av一区| 日本午夜精品一区二区三区电影| 精品一区二区三区视频| 日韩精品91亚洲二区在线观看 | 自拍偷自拍亚洲精品播放| 亚洲色图20p| 麻豆免费精品视频| 北条麻妃国产九九精品视频| 欧美日韩在线电影| 日韩一级黄色片| 亚洲九九爱视频| 日本欧美肥老太交大片| 99精品久久免费看蜜臀剧情介绍| 欧美福利一区二区| 亚洲精品中文在线影院| 国产精品456露脸| 欧美日韩精品免费观看视频| 国产精品网站在线观看| 亚洲大片免费看| 色婷婷亚洲综合| 国产精品嫩草影院com| 免费观看一级特黄欧美大片| 色吊一区二区三区| 亚洲美女电影在线| 99精品偷自拍| 亚洲私人影院在线观看| 国产一区 二区| 久久婷婷国产综合精品青草| 婷婷成人综合网| 日韩写真欧美这视频| 丝瓜av网站精品一区二区 | 成人av综合在线| 国产亚洲一区二区在线观看| 精品一区二区三区在线播放| av亚洲精华国产精华精| 久久综合成人精品亚洲另类欧美 | 亚洲影院理伦片| 欧美色偷偷大香| 精品综合免费视频观看| 日韩精品自拍偷拍| 成人av中文字幕| 一区二区日韩av| 精品国产一区二区精华| 粉嫩av亚洲一区二区图片| 亚洲日本中文字幕区| 欧美乱妇15p| 国产精品69久久久久水密桃| 亚洲欧美日韩精品久久久久| 欧美精品丝袜久久久中文字幕| 亚洲欧美另类小说| 成人精品国产一区二区4080| 成人免费视频在线观看| 成人精品一区二区三区中文字幕| 久久久久国产精品麻豆ai换脸| 国产成人日日夜夜| 午夜精品一区二区三区电影天堂 | 3d成人h动漫网站入口| 国产一区二区三区久久悠悠色av | 日本午夜一区二区| 久久精品一区八戒影视| 日本成人在线视频网站| 国产精一品亚洲二区在线视频| 91蜜桃免费观看视频| 91福利资源站| 一区二区三区免费观看|