Yii2使用Bootbox插件實(shí)現(xiàn)自定義彈窗
本次嘗試了一個(gè)新的小插件"bootbox"。
Yii2中使用了Bootstarp,讓界面更美觀,可是美中不足的是,在Gridview表格的Action里,刪除功能的彈窗實(shí)在有點(diǎn)與Bootstrap違和,網(wǎng)上找到了一種解決方案,分享下使用此插件的過(guò)程。
Bootbox.js,是一個(gè)小型的JavaScript庫(kù)用來(lái)創(chuàng)建簡(jiǎn)單的可編程對(duì)話框,基于Bootstrap的Modal(模態(tài)框)來(lái)創(chuàng)建。
官方說(shuō)明
http://bootboxjs.com/v3.x/index.html
Bootbox.js下載
我們可以在GitHub上找到開源的bootbox.js下載
https://github.com/makeusabrew/bootbox
如何使用此插件?
結(jié)合Yii2的GridView,我們來(lái)自定義Bootbox樣式的彈窗:
一、覆蓋yii.js模塊
Yii2自帶的yii.js中定義了生成confirm對(duì)話框,以及執(zhí)行action操作。
我們可以用過(guò)覆蓋js方法來(lái)達(dá)到目的。
在@app/web/js/路徑下創(chuàng)建一個(gè)javascript文件,比如main.js。
代碼如下:
yii.allowAction = function ($e) {
var message = $e.data('confirm');
return message === undefined || yii.confirm(message, $e);
};
// --- Delete action (bootbox) ---
yii.confirm = function (message, ok, cancel) {
bootbox.confirm(
{
message: message,
buttons: {
confirm: {
label: "OK"
},
cancel: {
label: "Cancel"
}
},
callback: function (confirmed) {
if (confirmed) {
!ok || ok();
} else {
!cancel || cancel();
}
}
}
);
// confirm will always return false on the first call
// to cancel click handler
return false;
}
二、注冊(cè)你的資源包
需要注冊(cè)bootbox.js和main.js文件。
修改文件:@app/assets/Assets.php
代碼如下:
namespace backend\assets;
use yii\web\AssetBundle;
class AppAsset extends AssetBundle
{
public $basePath = '@webroot';
public $baseUrl = '@web';
public $css = ['css/site.css'];
// 注冊(cè)js資源
public $js = ['js/bootbox.js', 'js/main.js'];
public $depends = [
'yii\web\YiiAsset',
'yii\bootstrap\BootstrapAsset',
];
}
三、自定義Modal框
了解下bootbox.js源碼,可以知道bootbox.js使用的是bootstarp的modal框,我們可以根據(jù)需求
修改bootbox.js源碼中的"templates"變量,自定義Modal樣式。
看下對(duì)比結(jié)果:
修改前:

修改后:

瞬間舒服多了,彈窗功能變的不再那么違和。類似這樣的彈窗插件有很多,我想可以用同樣的方法來(lái)實(shí)現(xiàn)使用其他的插件。
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- Yii框架中jquery表單驗(yàn)證插件用法示例
- Yii的Srbac插件用法詳解
- Yii安裝EClientScript插件擴(kuò)展實(shí)現(xiàn)css,js文件代碼壓縮合并加載功能
- Yii2組件之多圖上傳插件FileInput的詳細(xì)使用教程
- Yii2實(shí)現(xiàn)ajax上傳圖片插件用法
- Yii2框架引用bootstrap中日期插件yii2-date-picker的方法
- 從零開始學(xué)YII2框架(四)擴(kuò)展插件yii2-kartikgii
- 從零開始學(xué)YII2框架(三)擴(kuò)展插件yii2-gird
- 從零開始學(xué)YII2框架(二)通過(guò) Composer 安裝擴(kuò)展插件
- Yii結(jié)合CKEditor實(shí)現(xiàn)圖片上傳功能
- Yii框架引用插件和ckeditor中body與P標(biāo)簽去除的方法
相關(guān)文章
javascript中使用replaceAll()函數(shù)實(shí)現(xiàn)字符替換的方法
第一次發(fā)現(xiàn)JavaScript中replace()?方法如果直接用str.replace("-","!")?只會(huì)替換第一個(gè)匹配的字符.2010-12-12
How to Auto Include a Javascript File
How to Auto Include a Javascript File...2007-02-02
cnblogs csdn 代碼運(yùn)行框?qū)崿F(xiàn)代碼
大家用cnblogs,csdn博客發(fā)布技術(shù)文檔的時(shí)候,可以用下面的代碼實(shí)現(xiàn)運(yùn)行功能。當(dāng)然大家看了源碼就會(huì)發(fā)現(xiàn)其實(shí)方法還有很多。有更好的方法就發(fā)布一下啊。2009-11-11
JS設(shè)置定時(shí)循環(huán)執(zhí)行某任務(wù)的方法示例
在Web前端開發(fā)中,定時(shí)執(zhí)行某個(gè)任務(wù)是常見(jiàn)的需求之一,無(wú)論是為了實(shí)現(xiàn)輪詢服務(wù)器獲取最新數(shù)據(jù)、定期更新用戶界面還是其他周期性操作,JavaScript提供了多種方法來(lái)設(shè)置定時(shí)循環(huán),本文將深入探討如何使用setTimeout和setInterval來(lái)定時(shí)執(zhí)行任務(wù),需要的朋友可以參考下2025-02-02
js 返回時(shí)間戳所對(duì)應(yīng)的具體時(shí)間
返回unix時(shí)間戳所對(duì)應(yīng)的具體時(shí)間的代碼2010-07-07

