ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript での変数パラメータの受け渡しに関する問題と解決策 call_javascript スキル

JavaScript での変数パラメータの受け渡しに関する問題と解決策 call_javascript スキル

WBOY
WBOYオリジナル
2016-05-16 15:34:271238ブラウズ

パラメータを受け取る js メソッドがあります:

コードをコピーします コードは次のとおりです:

関数 f1(myValue){ アラート(myValue) }

には変数があります:

コードをコピーします コードは次のとおりです:

var passValue="Hello World";

このメソッドを呼び出すとき (Ajax が送信するときに表示されます):

@Ajax.ActionLink("Text","Controller",new{parameter},new AjaxOptions(){ HttpMethod="post",OnSuccess="f1(PassValue)" })

ここで最後の OnSuccess に注意してください。変数を直接スローすると、変数は文字列とみなされます

OnSuccess="f1(" PassValue ")" に変更すると機能しません

検索した結果、エスケープ文字が必要であることがわかりました

OnSuccess="f1('" PassValue "')"

大丈夫です

しかし、上記の Ajax を呼び出すときは注意しませんでしたが、これは非同期呼び出しメソッド f1() にパラメータを渡すだけです

したがって、@Ajax を通常の A タグに変更する必要はありません。そうしないと、コントローラーが 2 回呼び出されます。

ps:js はメソッドをパラメータとして呼び出します

<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="content-type" content="text/html; charset=utf-8" />
  <title>js调用</title>  
  <script src="cssjs/jquery.js" type="text/javascript"></script>
  <script type="text/javascript">
    $().ready(function () {
      $.dialog = function (settings) {
        if ($.isFunction(settings.okCallback)) {
          if (settings.height == null) {
            if (settings.okCallback.apply() != false) {
              alert("1");
            }
          } else {
            
            if (settings.okCallback.call(this, settings.height) != false) {
              alert("2");
            }
            
            /*
            if (settings.okCallback.apply(this, arguments) != false) {
              alert("2");
            }
            */
          }
        }
      }
    });    
  </script>
  <script type="text/javascript">
    $(function () {
      $.dialog({
        okCallback: print,
        height: {data:"你好"}
      });
    });
  function print(ee1) {
    alert("print(ee1)");
    
    alert(ee1.data);
    
    /*
    alert(ee1.height.data);
    */
  /*
  function print(a, b, c, d) {
  alert(a + b + c + d);
  }
  function example(a, b, c, d) {
  //用call方式借用print,参数显式打散传递
  print.call(this, a, b, c, d);
  //用apply方式借用print, 参数作为一个数组传递,
  //这里直接用JavaScript方法内本身有的arguments数组
  print.apply(this, arguments);
  //或者封装成数组
  print.apply(this, [a, b, c, d]);
  }
  //下面将显示"背光脚本"
  example("背", "光", "脚", "本"); 
  */
  </script>
</head>
<body> 
</body>
</html>
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。