2019-06-01 17:52:41 ixygj197875 阅读数 251

按钮

Bootstrap中的按钮插件(button.js)被赋予多种功能,如为工具条之类的组件赋予状态提示功能、状态切换功能、或者按钮组的功能。

在页面多次加载之间,Firefox 仍然保持表单控件的状态(禁用状态和选择状态)。一个解决办法是为按钮设置 autocomplete="off"属性。

状态提示

通过自定义属性和简单的JavaScript编程,就可以让按钮具有状态提示功能。比如,没有点击按钮时,正常显示;点击按钮时,触发相应的状态,并显示该状态对应的文本信息。

1)加载状态

要让按钮显示加载状态,首先要给按钮添加 data-loading-text 属性,它的值为加载状态要显示的文本信息,如 "Loading...":


 
  1. <button type="button" class="btn btn-primary" data-loading-text="Loading...">Loading state</button>

还要为按钮定义单击事件,并在点击时调用 button('loading') 方法,来触发加载状态。代码如下:


 
  1. <script>
  2. $('.btn').click(function() {
  3.   $(this).button('loading')
  4. });
  5. </script>

现在,按钮就被赋予了加载状态提示功能。没有点击时,按钮正常显示。效果如图 4‑12所示:

按钮默认状态

图4-12 按钮默认状态

当点击按钮时,会触发加载状态,按钮的文本会变成 data-loading-text 属性的值。Bootstrap还为加载状态的按钮定义了特定的样式,加载过程中,按钮被自动禁用,它会变灰,不再响应单击。效果如图 4‑13所示:

按钮加载状态

图4-13 按钮加载状态

2)自定义状态

除了加载状态外,还可以为按钮自定义任意状态,只需为按钮添加 data-xxx-text 属性,并在点击按钮时调用 button('xxx') 方法即可。

比如,为按钮自定义 complete 状态,首先为按钮添加 data-complete-text 属性,属性的值为 complete 状态要显示的文本信息:


 
  1. <button type="button" class="btn" data-complete-text="finished!" >complete</button>

再为按钮定义单击事件,并在点击时调用 button('complete') 方法:


 
  1. <script>
  2. $('.btn').click(function() {
  3.   $(this).button('complete')
  4. });
  5. </script>

现在,按钮就被赋予了 complete 状态提示功能。没有点击时,按钮正常显示。当点击按钮时,会触发 complete 状态,按钮的文本会变成 data-complete-text 属性的值。效果如图 4‑14所示:

按钮自定义状态

图4-14 按钮自定义状态

3)重置状态

如果想让按钮的文本回到最初的样子,可以调用 button('reset') 方法来重置按钮的状态,让它显示初始的文本。代码如下:


 
  1. <script>
  2. $('.btn').button('reset')
  3. </script>

如果没有为按钮定义 data-complete-text 属性,重置状态下会显示初始的文本,如果定义了 data-complete-text 属性,则显示 data-complete-text 属性指定的文本。

关于作者

歪脖先生,十五年以上软件开发经验,酷爱Web开发,精通 HTML、CSS、JavaScript、jQuery、JSON、Python、Less、Bootstrap等,著有《HTML宝典》、《揭秘CSS》、《Less简明教程》、《JSON教程》、《Bootstrap2用户指南》、《Bootstrap3实用教程》,并全部在 GitHub 上开源。

2015-08-22 10:38:48 u011429828 阅读数 4394

项目前端使用了bootstrap,想使用bootstrap的loading按钮作为ajax请求数据时的等待。参考bootstrap最新教程:

 $(".btn").click(function(){
         $(this).button('loading').delay(1000).queue(function() {

           $(this).button('reset');
         });        
      });

按钮第一次点击,如果出现错误后,重新执行

$btn.button('reset')
恢复按钮的可用状态。但是点击第二次时,会一直为loading....  处于disabled="disabled"  禁用状态,按钮不能恢复。
     后发现问题在queue()这个遍历方法上,queue() 方法显示或操作在匹配元素上执行的函数队列,队列运行在元素上异步地调用动作序列,而不会终止程序执行,
当通过 .queue() 添加函数时,应当确保最终调用了 .dequeue(),这样下一个排队的函数才能执行。
     问题解决:将$(this).button('reset')  改为$(this).button('reset').dequeue();即可

2016-08-17 13:33:01 qq_35514952 阅读数 790

Bootstrap里按钮的动态实现

这是bootstrap教程上的加载按钮实现代码:

<button type="button" id="myButton" data-loading-text="Loading..." class="btn btn-primary" autocomplete="off">
  Loading state
</button>

<script>
  $('#myButton').on('click', function () {
    var $btn = $(this).button('loading')
    // business logic...
    $btn.button('reset')
  })
</script>

注意// business logic…这一行要自己写
在网站制作中,我们常常会需要实现这样一个功能:
按“获取验证码”按钮,出现倒计时。
对上面的代码稍加修改,就可以实现

<button type="button" id="myButton" data-loading-text="Loading..." class="btn btn-primary" autocomplete="off">
  Loading state
</button>
<script>
  $('#myButton').on('click', function () {
    var btn = $("#myButton");
      btn.button('loading');
      setTimeout(function () { btn.button('reset'); },2000);
  })
</script>

这里用了$(‘#myButton’).on(‘click’, function (){…});
我们还可以使用onclick=”loag()”

<button type="button" id="myButton" data-loading-text="Loading..." class="btn btn-primary" autocomplete="off" onclick="loag()">
  Loading state
</button>
<script>
   function loag() {
      var btn = $("#myButton");
      btn.button('loading');
      setTimeout(function () { btn.button('reset'); },2000);
    }
</script>

是不是很有趣呢O(∩_∩)O!

2016-12-01 22:32:32 womeng2009 阅读数 15089

Button在Bootstrap中可以添进一些交互,需要引入button.js或者bootstrap.js或压缩版的bootstrap.min.js。

如需向按钮添加加载状态,只需向按钮中添加data-loading-text="Loading..." 作为其属性即可。如下是官方给出的使用方法:

<button type="button" id="myButton" data-loading-text="Loading..." class="btn btn-primary" autocomplete="off">
  Loading state
</button>
<script>
  $('#myButton').on('click', function () {
    var $btn = $(this).button('loading')
    // business logic...
    $btn.button('reset')
  })
</script>
但是今天在项目中运用并没有得到相应的效果,网上有人说F12追踪js运行看到缺少文件,或许以前有这个问题,但本人用的bootstrap3.3并没有缺少文件,经过反复测试发现看不到效果是因为没有设置延迟时间,在加载的同时又reset了。修改后代码如下所示:

<button type="button" id="saveButton" data-loading-text="保存中..." onclick="saveToModal();" class="btn btn-primary" autocomplete="off">
保存
</button>
<SCRIPT>
	function saveToModal(){
		var btn = $("#saveButton");
    		btn.button('loading');
    		setTimeout(function () { btn.button('reset'); },1000);
	
document.getElementById("StudentNum-p").innerHTML = document.getElementById("StudentNum").value;
document.getElementById("StudentName-p").innerHTML = document.getElementById("StudentName").value;
}
</SCRIPIT>

这是在实际项目中截取出来的片段。





2019-01-04 00:40:25 LoveyourselfJiuhao 阅读数 518

按钮(Button)插件

通过按钮(Button)插件,您可以添加进一些交互,比如控制按钮状态,或者为其他组件(如工具栏)创建按钮组。 如果您想要单独引用该插件的功能,那么您需要引用 button.js。或者,您可以引用 bootstrap.js 或压缩版的 bootstrap.min.js。 

加载状态

如需向按钮添加加载状态,只需要简单地向 button 元素添加 data-loading-text="Loading..." 作 为其属性即可,如下面实例所示:

<button id="fat-btn" class="btn btn-primary" data-loading-text="Loading..."     type="button"> 加载状态 
</button> 
<script> 
     $(function() { 
          $(".btn").click(function(){ 
               $(this).button('loading').delay(1000).queue(function() { 
                    // $(this).button('reset'); 
                }); 
          });
      }); 
 }); 

单个切换

如需激活单个按钮的切换(即改变按钮的正常状态为按压状态,反之亦然),只需向 button 元 素添加 data-toggle="button" 作为其属性即可,如下面实例所示: 

<button type="button" class="btn btn-primary"  
   data-toggle="button"> 单个切换 
</button> 

单选按钮(Radio)或  复选框(Checkbox)

可以创建单选按钮组,并通过向 btn-group 添加 data 属性 data-toggle="buttons" 来 添加单选按钮组的切换,其中input type="radio"  或  input type="checkbox",样例:

<div class="btn-group" data-toggle="buttons"> 
   <label class="btn btn-primary"> 
      <input type="radio" name="options" id="option1"> 选项 1 
   </label>
   <label class="btn btn-primary"> 
      <input type="radio" name="options" id="option2"> 选项 2 
   </label> 
   <label class="btn btn-primary"> 
      <input type="radio" name="options" id="option2"> 选项 3 
   </label> 
</div>

用法

您可以 通过 JavaScript 启用按钮(Button)插件,如下所示: 

$('.btn').button() 

方法 

代码实例

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>按钮(Button)插件</title>
    <!-- Bootstrap -->
    <link rel="stylesheet" href="../css/bootstrap.min.css">
    <script src="../js/jquery-1.11.1.min.js"></script>
    <script src="../js/bootstrap.min.js"></script>
</head>
<body>
    <div class="container">
        <h4>按钮加载状态</h4>
        <!-- 向 button 元素添加 data-loading-text="Loading..."  
        data-loading-text="*":JS执行button("loading"),替换按钮文本
        data-complete-text="*":JS执行button("complete"),替换按钮文本
        -->
        <div class="container" style="padding:20px">
            <button class="btn btn-primary btn-loading" type="button" data-loading-text="加载中...">获取数据</button>
                <button class="btn btn-primary btn-string" type="button" >演示button(String)</button>
                <button class="btn btn-primary btn-complete" data-loading-text="加载中..."  data-complete-text="Loading finished" type="button" >演示button(complete)</button>
        </div>
        <h4>单个切换,两个或多个按钮相互切换状态</h4>
        <!-- 激活单个按钮的切换(即改变按钮的正常状态为按压状态,反之亦然),只需向 button 元 素添加 data-toggle="button" 作为其属性即可 -->
        <div class="container" style="padding:20px">
            <button class="btn btn-success" data-toggle="button">点击凹陷点击凸起</button>
            <button class="btn btn-warning" data-toggle="button">点击凹陷点击凸起</button>
        </div>
        <h4>按钮单选按钮(Radio</h4>
        <!-- 向 btn-group 添加 data 属性 data-toggle="buttons" 来 添加单选按钮组的切换 -->
        <div class="container">
            <div class="btn-group" data-toggle="buttons">
                <label  class="btn btn-primary">
                    <input type="radio" name="options" id="opt1">选项1
                </label>
                <label  class="btn btn-primary">
                    <input type="radio" name="options" id="opt2">选项2
                </label>
                <label  class="btn btn-primary">
                    <input type="radio" name="options" id="opt3">选项3
                </label>
            </div>
        </div>
        <h4>按钮复选框(Checkbox)</h4>
        <!-- 向btn-group 添加 data 属性 data-toggle="buttons" 来添加复选框 组的切换 -->
        <div class="container">
            <div class="btn-group" data-toggle="buttons">
                <label  class="btn btn-primary">
                    <input type="checkbox">选项1
                </label>
                <label  class="btn btn-primary">
                    <input type="checkbox">选项2
                </label>
                <label  class="btn btn-primary">
                    <input type="checkbox">选项3
                </label>
            </div>
        </div>
    </div>
</body>
<script>
    $(function () {
        $(".btn-loading").click(function () {
            //button("loading"):加载时,按钮内容替换为data-loading-text属性定义内容
            //button("reset"):按钮内容初始化
            //delay(1000):等待1000毫秒
            //queue():加载时进入列队执行脚本
            $(this).button("loading").delay(1000).queue(function () {
                //加载1000毫秒后,进入列队把按钮内容还原为初始状态
                $(this).button("reset");
            })
        });
        
        $(".btn-string").click(function(){
            //替换自定义文本
            $(this).button("string");
        });
        
        $(".btn-complete").click(function(){
            $(this).button("loading").delay(1000).queue(function(){
                //加载1000毫秒后,进入列队,按钮初始化并替换为data-complete-text属性定义内容
                $(this).button("complete");
            });
        })
    })
</script>
</html>

 显示效果:

Bootstrap 按钮状态

阅读数 1022

Bootstrap按钮插件

阅读数 206

没有更多推荐了,返回首页