亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? validationtaglib.groovy

?? grails用戶使用指南
?? GROOVY
字號:
/* Copyright 2004-2005 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *      http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT c;pWARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */import org.springframework.validation.Errors;import org.springframework.context.NoSuchMessageException;import org.springframework.web.servlet.support.RequestContextUtils as RCU;import org.codehaus.groovy.grails.commons.GrailsClassUtils as GCU;/***  A  tag lib that provides tags to handle validation and errors** @author Graeme Rocher* @since 17-Jan-2006*/class ValidationTagLib {    /**     * Checks if the request has errors either for a field or global errors     */    def hasErrors = { attrs, body ->        def model = attrs['model']        def checkList = []        if(model) {            checkList = model.findAll { k,v ->                grailsApplication.isGrailsDomainClass(v.class)            }        }        if(attrs['bean']) {            checkList << attrs['bean']        }        else {			if(request.attributeNames) {				request.attributeNames.each { ra ->					if(ra) {                        if(ra instanceof Errors)                            checkList << ra                        else if(grailsApplication.isGrailsDomainClass(ra.class))                            checkList << ra					}				}			}        }        for(i in checkList) {            def errors = null            if(grailsApplication.isGrailsDomainClass(i.class)) {                if(i.hasErrors())                    errors = i.errors            }            else if(i instanceof Errors) {               errors = i            }            if(errors) {                if(attrs['field']) {                    if(errors.hasFieldErrors(attrs['field'])) {                        body()                    }                }                else {                    body()                }            }        }    }    /**     * Loops through each error for either field or global errors     */    def eachError = { attrs, body ->        def model = attrs['model']        def errorList = []        if(model) {            errorList = model.findAll { k,v ->                grailsApplication.isGrailsDomainClass(v.class)            }        }        if(attrs['bean']) {            errorList << attrs['bean']        }        else {            request.attributeNames.each {                def ra = request[it]                if(ra) {                    if(ra instanceof Errors)                        errorList << ra                    else if(grailsApplication.isGrailsDomainClass(ra.class))                        errorList << ra                }            }        }        for(i in errorList) {            def errors = null            if(grailsApplication.isGrailsDomainClass(i.class)) {                if(i.hasErrors())                    errors = i.errors            }            else if(i instanceof Errors) {               errors = i            }            if(errors && errors.hasErrors()) {                if(attrs['field']) {                    if(errors.hasFieldErrors(attrs['field'])) {                        errors.getFieldErrors( attrs["field"] ).each {                            body(it)                        }                    }                }                else {                    errors.allErrors.each {                        body( it )                    }                }            }        }    }    /**     * Loops through each error and renders it using one of the supported mechanisms (defaults to "list" if unsupported)     */    def renderErrors = { attrs, body ->        def renderAs = attrs.remove('as')        if(!renderAs) renderAs = 'list'        if(renderAs == 'list') {            out << "<ul>"            eachError(attrs, {                out << "<li>"                message(error:it)                out << "</li>"              }            )            out << "</ul>"        }    }    /**     * Resolves a message code for a given error or code from the resource bundle     */    def message = { attrs ->          def messageSource = grailsAttributes                                .getApplicationContext()                                .getBean("messageSource")          def locale = RCU.getLocale(request)          if(attrs['error']) {                def error = attrs['error']                def defaultMessage = ( attrs['default'] ? attrs['default'] : error.defaultMessage )                def message = messageSource.getMessage( error.code,                                                        error.arguments,                                                        defaultMessage,                                                        locale )                if(message) {                    out << message                }                else {                    out << error.code                }          }          if(attrs['code']) {                def code = attrs['code']                def args = attrs['args']                 def defaultMessage = ( attrs['default'] ? attrs['default'] : code )                def message = messageSource.getMessage( code,                                                        args == null ? null : args.toArray(),                                                        defaultMessage,                                                        locale )                if(message) {                    out << message                }                else {                    out << code                }          }    }    // Maps out how Grails contraints map to Apache commons validators    static CONSTRAINT_TYPE_MAP = [ email : 'email',                                             creditCard : 'creditCard',                                             match : 'mask',                                             blank: 'required',                                             nullable: 'required',                                             maxSize: 'maxLength',                                             minSize: 'minLength',                                             range: 'intRange',                                             size: 'intRange',                                             length: 'maxLength,minLength' ]    /**     * Validates a form using Apache commons validator javascript against constraints defined in a Grails     * domain class     *     * TODO: This tag is a work in progress     */    def validate = { attrs, body ->        def form = attrs["form"]        def againstClass = attrs["against"]        if(!form)            throwTagError("Tag [validate] is missing required attribute [form]")        if(!againstClass) {            againstClass = form.substring(0,1).toUpperCase() + form.substring(1)        }        def app = grailsAttributes.getGrailsApplication()        def dc = app.getGrailsDomainClass(againstClass)        if(!dc)            throwTagError("Tag [validate] could not find a domain class to validate against for name [${againstClass}]")        def constrainedProperties = dc.constrainedProperties.collect { k,v -> return v }        def appliedConstraints = []        constrainedProperties.each {           appliedConstraints += it.collect{ it.appliedConstraints }        }        appliedConstraints = appliedConstraints.flatten()        def fieldValidations = [:]        appliedConstraints.each {            def validateType = CONSTRAINT_TYPE_MAP[it.name]            if(validateType) {                if(fieldValidations[validateType]) {                    fieldValidations[validateType] << it                }                else {                     fieldValidations[validateType] =  [it]                }            }        }        out << '<script type="text/javascript">\n'        fieldValidations.each { k,v ->           def validateType = k           if(validateType) {                def validateTypes = [validateType]                if(validateType.contains(",")) {                    validateTypes = validateType.split(",")                }                validateTypes.each { vt ->                    // import required script                    def scriptName = "org/apache/commons/validator/javascript/validate" + vt.substring(0,1).toUpperCase() + vt.substring(1) + ".js"                    def inStream = getClass().classLoader.getResourceAsStream(scriptName)                    if(inStream) {                        out << inStream.text                    }                    out << "function ${form}_${vt}() {"                    v.each { constraint ->                           out << "this.${constraint.propertyName} = new Array("                           out << "document.forms['${form}'].elements['${constraint.propertyName}']," // the field                           out << '"Test message"' // TODO: Resolve the actual message                           switch(vt) {                                case 'mask': out << ",function() { return '${constraint.regex}'; }";break;                                case 'intRange': out << ",function() { if(arguments[0]=='min') return ${constraint.range.from}; else return ${constraint.range.to} }";break;                                case 'floatRange': out << ",function() { if(arguments[0]=='min') return ${constraint.range.from}; else return ${constraint.range.to} }";break;                                case 'maxLength': out << ",function() { return ${constraint.maxSize};  }";break;                                case 'minLength': out << ",function() { return ${constraint.minSize};  }";break;                           }                           out << ');\n'                    }                    out << "}\n"                }            }        }        out << 'function validateForm(form) {\n'         fieldValidations.each { k,v ->               def validateType = k.substring(0,1).toUpperCase() + k.substring(1)               out << "if(!validate${validateType}(form)) return false;\n"         }        out << 'return true;\n';        out << '}\n'      //  out << "document.forms['${attrs['form']}'].onsubmit = function(e) {return validateForm(this)}\n"        out << '</script>'    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品在线网站| 欧美理论在线播放| 日韩视频123| 一区二区在线免费| 理论电影国产精品| 日本高清不卡在线观看| 日韩欧美国产一二三区| 久久久久久久久蜜桃| 亚洲va欧美va国产va天堂影院| 国内精品免费**视频| 欧美视频中文字幕| 欧美精品一区二区久久婷婷 | 日韩av电影天堂| 99视频精品免费视频| 日韩美一区二区三区| 亚洲精选免费视频| 国产一区二区女| 日韩一级高清毛片| 亚洲精品视频在线| 处破女av一区二区| 日韩精品一区二区三区中文精品| 午夜精品久久一牛影视| 97精品国产露脸对白| 久久婷婷国产综合精品青草| 亚洲成人免费av| 欧美伊人久久大香线蕉综合69| 中文字幕高清不卡| 国产呦萝稀缺另类资源| 欧美久久一区二区| 日精品一区二区三区| 色婷婷综合久久久久中文一区二区 | 亚洲欧洲精品一区二区三区| 国产大陆a不卡| 欧美精品一区二区三| 欧美aⅴ一区二区三区视频| 91精品在线观看入口| 一区二区三区国产豹纹内裤在线| 成人黄色电影在线| 国产欧美一区二区三区网站 | 久久精品视频一区| 日本美女视频一区二区| 欧美丰满高潮xxxx喷水动漫| 亚洲电影激情视频网站| 欧美色网站导航| 亚洲精品少妇30p| 91成人免费网站| 亚洲女同一区二区| 不卡av在线网| 中文字幕日韩欧美一区二区三区| www.久久精品| 国产精品美女久久久久aⅴ| 国产成人亚洲综合色影视| 久久精品在线免费观看| 中文字幕一区二区在线观看 | 奇米一区二区三区| 欧美一级久久久| 蜜桃在线一区二区三区| 日韩欧美另类在线| 国产九色精品成人porny| 国产亚洲短视频| 成人免费av网站| 亚洲视频一二三区| 欧美性xxxxx极品少妇| 午夜视频一区二区| 91精品国产综合久久久久久久久久| 视频一区在线播放| 欧美亚洲综合久久| 午夜国产精品影院在线观看| 欧美一级理论片| 国产一区二区不卡老阿姨| 久久精品视频免费| 色欧美88888久久久久久影院| 亚洲一二三区视频在线观看| 欧美色视频在线| 日本视频一区二区三区| 精品成a人在线观看| 懂色av中文一区二区三区| 国产精品福利一区| 91国偷自产一区二区三区观看| 亚洲综合视频网| 欧美精品日韩综合在线| 久久不见久久见免费视频7| 国产欧美日韩三区| 91片在线免费观看| 亚洲高清视频的网址| 精品第一国产综合精品aⅴ| 粉嫩av一区二区三区粉嫩| 中文字幕一区二区三区乱码在线| 欧美日韩亚洲综合在线| 国产在线不卡一区| 一区二区三区在线观看视频| 日韩精品一区二区三区视频播放| 成人免费观看视频| 日本午夜精品视频在线观看| 中文字幕制服丝袜一区二区三区| 欧美日本国产视频| 成人网在线免费视频| 日本不卡视频在线| 1000部国产精品成人观看| 91精品国产美女浴室洗澡无遮挡| 福利电影一区二区| 日本一不卡视频| 亚洲精品少妇30p| 久久精品亚洲精品国产欧美| 欧美日本乱大交xxxxx| 成人av电影在线网| 九色综合狠狠综合久久| 亚洲青青青在线视频| 精品免费日韩av| 欧美四级电影网| www.日韩在线| 国产一区在线观看麻豆| 婷婷六月综合亚洲| 亚洲男人的天堂av| 日本一二三四高清不卡| 日韩一区二区麻豆国产| 欧美三区在线视频| av不卡一区二区三区| 国产一区二区三区不卡在线观看 | 日本不卡123| 亚洲综合免费观看高清完整版在线 | 在线精品视频一区二区三四| 懂色av一区二区三区免费观看 | 亚洲欧美自拍偷拍色图| 日韩一区二区精品| 欧美在线观看一二区| 狠狠色狠狠色综合系列| 亚洲大片在线观看| 国产精品视频你懂的| 日韩美女视频在线| 欧美日本一区二区三区四区| 99精品桃花视频在线观看| 激情综合色播五月| 日本大胆欧美人术艺术动态| 一区二区三区四区视频精品免费 | 丁香一区二区三区| 久久99精品久久久久| 亚洲综合自拍偷拍| 亚洲国产精品v| 中文字幕电影一区| 精品国产一区二区三区久久影院| 欧美日韩国产综合一区二区| av亚洲精华国产精华精华| 蜜臀av性久久久久蜜臀av麻豆| 亚洲自拍另类综合| 成人欧美一区二区三区在线播放| 久久综合久久久久88| 91精品在线观看入口| 欧美性极品少妇| 在线中文字幕一区二区| 99久精品国产| 99国产精品一区| 成人毛片老司机大片| 国产精品1区2区| 韩国女主播成人在线| 激情六月婷婷久久| 美国一区二区三区在线播放| 日韩精品久久久久久| 亚洲香肠在线观看| 午夜免费久久看| 日日欢夜夜爽一区| 婷婷亚洲久悠悠色悠在线播放 | 亚洲精品在线观| 日韩一区二区在线观看视频| 欧美刺激脚交jootjob| 日韩免费一区二区| 日韩精品一区二区三区老鸭窝| 制服丝袜日韩国产| 欧美成人三级电影在线| 精品国产污污免费网站入口| 日韩一区二区三区四区五区六区| 欧美一区二区三区播放老司机| 欧美一区二区三区公司| 日韩欧美一区二区久久婷婷| 日韩一级二级三级精品视频| 欧美岛国在线观看| 国产女人水真多18毛片18精品视频 | 国内精品视频一区二区三区八戒| 老司机精品视频一区二区三区| 蜜臀91精品一区二区三区| 日韩成人一级大片| 久久丁香综合五月国产三级网站| 韩国女主播一区| 国产成人精品三级| 国产精品1区2区3区| 91啪亚洲精品| 欧美图片一区二区三区| 欧美日韩国产三级| 久久综合色8888| 国产精品伦一区二区三级视频| 亚洲视频一二三| 亚洲午夜在线电影| 国产制服丝袜一区| 国产成人高清在线| 91色综合久久久久婷婷| 欧美巨大另类极品videosbest| 精品免费国产二区三区| 中文字幕 久热精品 视频在线| 中文字幕一区二区三区精华液| 午夜国产精品影院在线观看|