1

私は、各エントリが次のようになっているTwitterフィードを丸呑みにしました。

<entry>
    <id>tag:search.twitter.com,2005:30481912300568576</id>
    <published>2011-01-27T04:27:08Z</published>
    <link type="text/html" rel="alternate" href="http://twitter.com/LadyCourtz/statuses/30481912300568576"/>
    <title>U always right. ml</title>
    <content type="html">U always right. T <a href=&quot;http://twitter.com/Star_babey&quot;>@Star_babey</a>: But its only <b>twitter</b> tho star u wilding...lml</content>
    <updated>2011-01-27T04:27:08Z</updated>
    <link type="image/png" rel="image" href="http://a2.twimg.com/profile_images/1221429153/248287865_normal.jpg"/>

などなど

grails / GSPで行う必要があるのは、次のような画像を表示することでした <img src=${tweet.imgUrl}/> 。これは、XML結果をメタプログラミングするための良いケースのように見えましたが、Groovynoobyとして問題があります。

少なくとも2つの「リンク」ノードがあり、画像のURLにrel="image"属性があることを確認してください。だから私は試しました...

def records = new XmlSlurper().parse(response.data)
records.entry.metaClass.imgUrl = { -> return delegate.link?.find{it?.@rel == 'image'}?.@href }

しかし、このようなエラーは私が超えることはできません:

groovy.lang.MissingMethodException: No signature of method: groovy.util.slurpersupport.NodeChild.shout() is applicable for argument types: () values: []

助けていただければ幸いです

4

1 に答える 1

1

メタプログラミングの必要はないと思います。あなたはただできるはずです:

imageUrlList = new XmlSlurper().parse( response.data ).entry.link.findAll { it.@rel == 'image' }*.@href

次に、各場所の文字列のリストが残ります...

XmlSlurper全体をGSPに戻していますか?おそらく必要なデータを抽出して、それだけを送り返すでしょう

于 2011-01-28T10:26:40.450 に答える