3

QUnit で簡単なテストを行おうとしていますが、$(document).ready() 内で定義された関数が見つかりません。

test.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
  <title></title>
  <script type="text/javascript" src="qunit-git.js"></script>
  <script type="text/javascript" src="jquery.min.js"></script>
  <script type="text/javascript" src="code.js"></script>
  <script type="text/javascript" src="test.js"></script>
  <link rel="stylesheet" type="text/css" href="qunit-git.css" media="screen"/>
</head>
<body>
<h1 id="qunit-header">QUnit Test Suite</h1>
<h2 id="qunit-banner"></h2>
<div id="qunit-testrunner-toolbar"></div>
<h2 id="qunit-userAgent"></h2>
<ol id="qunit-tests"></ol>
</body>
</html>

test.js

test('Blah blah', function() {
  ok(mytest(), 'foo bar'
  );
});

code.js

$(document).ready(function() {
  var mytest = function() {
    return true;
  }
});

--> 「テスト #1 で死にました: mytest が定義されていません...」

4

1 に答える 1

9

テストを開始すると、コードの構造を改善する必要があることに気付く場合があります。関数を $(document).ready 内でローカル変数として定義するのは奇妙で、.ready 呼び出し以外ではアクセスできないようにします。その機能を別の場所に移動します。

于 2011-06-17T20:16:52.660 に答える