Yii2使用Bootbox插件实现自定义弹窗


Posted in Javascript onApril 02, 2015

本次尝试了一个新的小插件"bootbox"。

Yii2中使用了Bootstarp,让界面更美观,可是美中不足的是,在Gridview表格的Action里,删除功能的弹窗实在有点与Bootstrap违和,网上找到了一种解决方案,分享下使用此插件的过程。

Bootbox.js,是一个小型的JavaScript库用来创建简单的可编程对话框,基于Bootstrap的Modal(模态框)来创建。

官方说明

http://bootboxjs.com/v3.x/index.html

Bootbox.js下载

我们可以在GitHub上找到开源的bootbox.js下载

https://github.com/makeusabrew/bootbox

如何使用此插件?

结合Yii2的GridView,我们来自定义Bootbox样式的弹窗:

一、覆盖yii.js模块

Yii2自带的yii.js中定义了生成confirm对话框,以及执行action操作。

我们可以用过覆盖js方法来达到目的。

在@app/web/js/路径下创建一个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;
}

二、注册你的资源包

需要注册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'];
  // 注册js资源
  public $js = ['js/bootbox.js', 'js/main.js'];
  public $depends = [
    'yii\web\YiiAsset',
    'yii\bootstrap\BootstrapAsset',
  ];
}

三、自定义Modal框

了解下bootbox.js源码,可以知道bootbox.js使用的是bootstarp的modal框,我们可以根据需求

修改bootbox.js源码中的"templates"变量,自定义Modal样式。

看下对比结果:

修改前:

Yii2使用Bootbox插件实现自定义弹窗

修改后:

Yii2使用Bootbox插件实现自定义弹窗

瞬间舒服多了,弹窗功能变的不再那么违和。类似这样的弹窗插件有很多,我想可以用同样的方法来实现使用其他的插件。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JS实现简单的Canvas画图实例
Jul 04 Javascript
非常好用的JsonToString 方法 简单实例
Jul 18 Javascript
基于dropdown.js实现的两款美观大气的二级导航菜单
Sep 02 Javascript
this,this,再次讨论javascript中的this,超全面(经典)
Jan 05 Javascript
不定义JQuery插件 不要说会JQuery
Mar 07 Javascript
jQuery实现点击按钮文字变成input框点击保存变成文字
May 09 Javascript
浅谈javascript中的 “ && ” 和 “ || ”
Feb 02 Javascript
javascript 显示全局变量与隐式全局变量的区别
Feb 09 Javascript
Bootstrap 表单验证formValidation 实现表单动态验证功能
May 17 Javascript
jQuery封装animate.css的实例
Jan 04 jQuery
echarts鼠标覆盖高亮显示节点及关系名称详解
Mar 17 Javascript
jquery实现掷骰子小游戏
Oct 24 jQuery
jquery制作多功能轮播图插件
Apr 02 #Javascript
Javascript中3个需要注意的运算符
Apr 02 #Javascript
原生JS实现响应式瀑布流布局
Apr 02 #Javascript
Javascript变量的作用域和作用域链详解
Apr 02 #Javascript
JavaScript中连接操作Oracle数据库实例
Apr 02 #Javascript
JavaScript中操作Mysql数据库实例
Apr 02 #Javascript
JavaScript使用ActiveXObject访问Access和SQL Server数据库
Apr 02 #Javascript
You might like
最令PHP初学者头痛的十四个问题
2006/07/12 PHP
PHP5中的时间相差8小时的解决办法
2008/03/28 PHP
IIS php环境配置PHP5 MySQL5 ZendOptimizer phpmyadmin安装与配置
2008/11/18 PHP
Mysql数据库操作类( 1127版,提供源码下载 )
2010/12/02 PHP
php从完整文件路径中分离文件目录和文件名的方法
2015/03/13 PHP
Centos6.5和Centos7 php环境搭建方法
2016/05/27 PHP
php redis实现对200w用户的即时推送
2017/03/04 PHP
PHP策略模式定义与用法示例
2017/07/27 PHP
Javascript下的keyCode键码值表
2007/04/10 Javascript
ExtJS 2.0实用简明教程 之Ext类库简介
2009/04/29 Javascript
javaScript 数值型和字符串型之间的转换
2009/07/25 Javascript
原生js实现shift/ctrl/alt按键的获取
2013/04/08 Javascript
JavaScript字符串对象slice方法入门实例(用于字符串截取)
2014/10/16 Javascript
简单介绍JavaScript数据类型之隐式类型转换
2015/12/28 Javascript
Vue自定义图片懒加载指令v-lazyload详解
2020/12/31 Javascript
十分钟带你快速了解React16新特性
2017/11/10 Javascript
javascript设计模式 ? 解释器模式原理与用法实例分析
2020/04/17 Javascript
python和pyqt实现360的CLable控件
2014/02/21 Python
跟老齐学Python之用Python计算
2014/09/12 Python
Python 的 Socket 编程
2015/03/24 Python
python中Switch/Case实现的示例代码
2017/11/09 Python
python学生信息管理系统(完整版)
2020/04/05 Python
Python Pandas分组聚合的实现方法
2019/07/02 Python
Django 过滤器汇总及自定义过滤器使用详解
2019/07/19 Python
Pytorch实现神经网络的分类方式
2020/01/08 Python
html5中如何将图片的绝对路径转换成文件对象
2018/01/11 HTML / CSS
如何在Canvas中添加事件的方法示例
2019/05/21 HTML / CSS
SmartBuyGlasses台湾:名牌眼镜,名牌太阳眼镜及隐形眼镜
2017/01/04 全球购物
巴西图书和电子产品购物网站:Saraiva
2017/06/07 全球购物
健身场所或家用健身设备:Life Fitness
2017/11/01 全球购物
Set里的元素是不能重复的,那么用什么方法来区分重复与否呢?
2016/08/18 面试题
社团2014年植树节活动总结
2014/03/11 职场文书
中学生综合素质自我评价
2015/03/06 职场文书
工作经历证明范本
2015/06/15 职场文书
运动会跳远广播稿
2015/08/19 职场文书
商业计划书之服装
2019/09/09 职场文书