0

既存のマークアップ:

<g:textField name="identifier"/>
<g:remoteLink action="newId" update="identifier">generate new id</g:remoteLink>

対応するHTMLマークアップ:

<input type="text" id="identifier" name="identifier">
<a onclick="new Ajax.Updater('guid','/webapp/domain/newId',{asynchronous:true,evalScripts:true});return false;" href="/webapp/domain/newId">generate</a>

リンクがクリックされたときに生成されるHTMLマークアップ:

<input type="text" id="identifier" name="identifier">THE-NEW-ID-HERE</input>
<a onclick="new Ajax.Updater('guid','/webapp/domain/newId',{asynchronous:true,evalScripts:true});return false;" href="/webapp/domain/newId">generate</a>
4

3 に答える 3

1

試す

<div id="updatableArea">
  <g:textField name="identifier"/>
</div>
<g:remoteLink action="newId" update="updatableArea">generate new id</g:remoteLink>

コントローラでHTMLフラグメントを返します

render(text:"<input type='text' id='identifier' name='identifier'>${newid}</input>", contentType:'text/html')

remoteLinkはノードのコンテンツを更新するだけなので、テキストフィールドの「値」は更新されません。

お役に立てば幸いです。

于 2010-03-18T20:31:41.143 に答える
1

onSuccessイベントを使用する別の方法:

def getName = {
   def exchange = Exchange.findById(params.id)
   if (!exchange) {
      render 'not found'
   }
   else {
      render(builder: "json") {
         exchange
      }
   }
}
...
<script>
   function fillName(e) {
      var obj = toJson(e);
      $('name').value = obj.name;
   }

   function toJson(obj) {
      return eval('(' + e.responseText + ')');
   }
</script>
...
<g:remoteLink action="getName" id="1" onSuccess="fillName(e)">
   Get
</g:remoteLink>
<input type='text' name='name' id='name'/>
于 2010-03-22T18:49:25.363 に答える
1

remoteLinkに以下を追加するだけです。

onSuccess="\$('identifier').value=e.responseText;"

したがって、最終結果(これは完全に機能します):

<g:textField name="identifier"/>
<g:remoteLink action="newId" onSuccess="\$('identifier').value=e.responseText;">generate new id</g:remoteLink>

注意すべき2つのこと:

  1. $は、その属性の「grails」処理のためにエスケープする必要があります。
  2. プロトタイプのJavaScriptライブラリを使用しています。他のライブラリでは構文が異なる場合がありますが、基本的な考え方は同じです。
于 2010-03-23T16:41:30.773 に答える