2

関数が vars の 2 つのプロパティを持つオブジェクトを返すために Dojo または JS でこれが可能かどうかわかりませんか? 私のコードは機能しませんが、私の要件と同じです:

function getObj()
{
    var var1 = 123; // 123 as simple case, but it could be a DOM node
    var var2 = 345; // another DOM node
    return {v1: var1, v2: var2}; // any way to get two values back?
}
....
var obj = getObj();
console.log("obj.v1: " + obj.v1 + "; obj.v2: " + obj.v2); // not working but possible?

OK、ここに私の本当の機能があります:

 dojo.requre("dojo.html");
 ....
 function getNodes()
 {
     var node = dojo.byId("div1"); // static <div> in html 
     var childen = "<div id='chart' style='width: 10px; height: 10px'></div><div id='legend'></div>";
     dojo.html.set(node, children); // add two divs as children
     var nodeChart = dojo.byId("chart");
     var nodeLegent = dojo.byId("legend");
     return {chart: nodeChart, legend: nodeLegend};
 }
 ...
 var nodes = getNodes();
 var nodeChart = nodes.chart; // OK div#chart
 var nodeLegend = nodes.legend; // nodes.legend is div#legend, but nodeLegend is undefined!
4

1 に答える 1

6

はい、可能です。そして、私はあなたのコードを試してみましたが、うまくいきます...

<html>
  <head>
    <script>
        function getObj(){
          var var1 = 123; // 123 as simple case, but it could be a DOM node
          var var2 = 345; // another DOM node
          return {v1: var1, v2: var2}; // any way to get two values back?
        }

        var obj = getObj();
        alert(obj.v1);
    </script>
  </head>
  <body>
    <h1>Test</h1>
  </body>
</html>

編集:

タイプミスがあります...

 var nodeLegent = dojo.byId("legend");
 return {chart: nodeChart, legend: nodeLegend};

あなたの変数はnodeLegentという名前ですが、 nodeLegend (未定義)を渡しています

気分を悪くしないでください。誰もがこの種の間違いを犯します。単に別の目が必要です。

于 2009-03-26T22:19:55.230 に答える