【问题标题】:Disable Close Modal on Outside Click在外部单击时禁用关闭模式
【发布时间】:2015-11-25 03:56:42
【问题描述】:

我正在制作一些使用带有 Materializecss 的模态的博客,但是我的模态 onclick 在外部和错误数据上存在问题,这是我的代码:

ma​​in.js

function changepassword(){
 var user = $('#userlog').val();
 var content  = ""; 

content += '<div id="modganpas" class="modal modal-fixed-footer">';
content += '<div class="modal-content">';
content += '<form>';        
content += '<style="text-align:center;font-size:12px;font-weight:bold;"><h3>change Password</h3>';
content += '<div><i class="material-icons">supervisor_account</i>';             
content += '</div>';
content += '<div class="row">';
content += '<div class="input-field col s12">';
content += '<input id="changeUsername" name="changeUsername" type="text" class="validate" disabled>';
content += '</div>';
content += '<div class="input-field col s12">';
content += '<input id="changePasswordold" maxlength="32" name="changePasswordold" type="password" class="validate">';
content += '<label for="changePasswordold">Password old</label></div>';
content += '<div class="input-field col s6">';
content += '<input id="changePasswordnew" maxlength="32" name="changePasswordnew" type="password" class="validate">';
content += '<label for="changePasswordnew">Password new</label></div>';
content += '<div class="input-field col s6">';
content += '<input id="changePasswordnew1" maxlength="32" name="changePasswordnew1" type="password" class="validate">';
content += '<label for="changePasswordnew1">Ulangi Password</label></div>';
content += '</div>';
content += '</form>';
content += '</div>';
content += '<div class="modal-footer">';
content += '<a href="#" onClick="check_ganpass()" id="btn_ok" class="modal-action modal-close waves-effect waves-green btn-flat ">Edit</a>';
content += '<a href="#!" onClick="cancelchangePassword()" class="modal-action modal-close waves-effect waves-red btn-flat ">Cancel</a>';
content += '</div>';
content += '</div>';
content += '</div>';

        $("#formodal").append(content);
        $('#changeUsername').val(user);}


//for check


    function check_ganpass(){
    var username = $('#changeUsername').val();
    var passwordold = $('#changePasswordold').val();
    var passwordnew = $('#changePasswordnew').val();
    var passwordnew1 = $('#changePasswordnew1').val();
    var urlnyah    = 'pas.php';

    $.ajax({
        url     : urlnyah,


        data    : 'username='+username+'&passwordold='+passwordold+'&passwordnew='+passwordnew+'&passwordnew1='+passwordnew1, 
        type    : 'POST',
        dataType: 'html',
        success : function(pesan){
            if(pesan=='ok,'){
                Materialize.toast('Data Telah Berubah',4000);
            }
            else{
                Materialize.toast(pesan,4000);
            }
        }
    });}

pas.php

<?php include("connection.php");
session_start();
$username = $_POST['username'];
$passwordold = md5($_POST['passwordold']);
$passwordnew = md5($_POST['passwordnew']);
$passwordnew1 = md5($_POST['passwordnew1']);
    $query = mysql_query("select * from tuser where username ='$username' and password = '$passwordold'");
    $data = mysql_num_rows($query);
    if ($data ==1)
    {   if ($passwordnew == $passwordnew1){     mysql_query("UPDATE tuser SET password='$passwordnew1' WHERE username='$username'");
            echo "ok,";
        } else {
        echo "Password new not same";
        }}else{
        echo "Password old werong.";}?>

connection.php

<?php $sambung=mysql_connect('localhost','root', '')or die('Not connected : ' . mysql_error());
mysql_select_db("test", $sambung)or die('Not connected : ' . mysql_error());?>

问题是如何禁用在框外单击时关闭模式以及输入的数据是否错误。

感谢指正。

【问题讨论】:

  • 您也可以编写自定义代码来隐藏模态框。
  • 谈话很便宜 给我看代码,请我使用materialize。

标签: javascript php jquery materialize


【解决方案1】:

//点击外部时禁用模态

$('#modalid').openModal({dismissible:false});

// 移除 modal-action modal-close in ok button

<a href="#" onClick="check_ganpass()" id="btn_ok" class="waves-effect waves-green btn-flat ">Edit</a>

// 在下面插入“Materialize.toast('Data Telah Berubah',4000);”

$('modalid').closeModal();

希望能回答您的问题。 :)

【讨论】:

    【解决方案2】:

    如果你只有一个模态,并且正在使用 jquery,你可以这样做:

    $('#myModal').modal()[0].M_Modal.options.dismissible = false;
    $('#myModal').modal('open');
    

    干杯

    【讨论】:

      【解决方案3】:

      试试这个

      $('#ModalID').modal({
          backdrop: 'static',
          keyboard: false
      })
      

      或在html中设置数据属性如下

      data-backdrop="static" data-keyboard="false"
      

      在弹出呼叫时

      希望这会有所帮助..

      【讨论】:

        【解决方案4】:

        您可以使用 dismissible 选项来防止这种情况发生

         $('#your_modal_ID').modal({
                        dismissible: false
                    })
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2019-07-12
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2020-11-24
          • 1970-01-01
          • 1970-01-01
          • 2019-02-01
          相关资源
          最近更新 更多