2

この例を使用して、小さなオブジェクト指向プロジェクトをセットアップしました

私がやり直しているページには、動的な数の入力フィールドを備えた注文機能がいくつかありました (記事のサイズ、サイズ S-XL、サイズ S-5XL など)。

次のように動的にラベル付けされた Coldfusion フィールドでは、次のようになります。

<input type="button" name="qty#counter#" id="qty-field#counter#"

私の CFC では、次のようにすべてのフォーム フィールドをリストしています。

<cfcomponent output="false" hint="">
   <cfscript>
     VARIABLES.Instance.Validation = {
         field_a="validation_criteria",
         field_b="validation_criteria",
         ...
         }
   </cfscript>
   <cffunction name="Defaults" access="public" returntype="struct" output="false" hint="">
      <cfscript>
      // form defaults
      var formDefaults = {
         field_a="", 
         field_b="",
     ...
         }
     </cfscript>
  <cfreturn formDefaults />     
</cffunction>

<cffunction name="Commit" ... do something with db

  <cfscript>                
var LOCAL = {};
    structAppend(defaultValues, VARIABLES.Instance.FormData);
    LOCAL.xxx = defaultValues;
  </cfscript>

  ... do stuff with LOCAL

そのため、渡されたすべてのフォーム フィールドを含むオブジェクトを作成し、CFC 内で作業を行います。オブジェクト指向でないページの cfparam のようなものです。

私の質問:
ページに 200 個の入力がある場合 (簡単に...)、それらを 1 ~ 200 ごとにパラメーター設定したり、デフォルトを 200 個の入力で拡張したりすることはできません。だから、私の質問:ダミーフィールド1〜500を追加するよりもフォームフィールドの動的数を「パラメータ化」する簡単な方法はありますか?これはすべてのケースで十分です(これは最悪の選択肢です...)

AND : これを MySQL に移植したい場合... Coldfusion では、次のようなクエリがあります。

<cfoutput query="s">
    <cfquery datasource="db">
    UPDATE pos
    SET qty = "#evaluate("qty#id#")#"
    WHERE id = "#client_id#" and id = "#id#"
    </cfquery>
</cfoutput>

Coldfusion でループして、storedProc を i-numbers 回呼び出す以外の方法はありますか?

ご意見ありがとうございます。

編集:
したがって、私の現在のソリューションは次のようになります。

 , ean1="", ean2="", ean3="", ean4="", ean5="", ean6="", ean7="", ean8="", ean9="", ean10=""
, ean11="", ean12="", ean13="", ean14="", ean15="", ean16="", ean17="", ean18="", ean19="", ean20=""
, ean21="", ean22="", ean23="", ean24="", ean25="", ean26="", ean27="", ean28="", ean29="", ean30="" 
, ean31="", ean32="", ean33="", ean34="", ean35="", ean36="", ean37="", ean38="", ean39="", ean40="" 
, ean41="", ean42="", ean43="", ean44="", ean45="", ean46="", ean47="", ean48="", ean49="", ean50="" 
, ean51="", ean52="", ean53="", ean54="", ean55="", ean56="", ean57="", ean58="", ean59="", ean60="" 
, ean61="", ean62="", ean63="", ean64="", ean65="", ean66="", ean67="", ean68="", ean69="", ean70="" 
, ean71="", ean72="", ean73="", ean74="", ean75="", ean76="", ean77="", ean78="", ean79="", ean80="" 
, ean81="", ean82="", ean83="", ean84="", ean85="", ean86="", ean87="", ean88="", ean89="", ean90="" 
, ean91="", ean92="", ean93="", ean94="", ean95="", ean96="", ean97="", ean98="", ean99="", ean100=""

// more
, menge1="", menge2="", menge3="", menge4="", menge5="", menge6="", menge7="", menge8="", menge9="", menge10=""
, menge11="", menge12="", menge13="", menge14="", menge15="", menge16="", menge17="", menge18="", menge19="", menge20=""
, menge21="", menge22="", menge23="", menge24="", menge25="", menge26="", menge27="", menge28="", menge29="", menge30="" 
, menge31="", menge32="", menge33="", menge34="", menge35="", menge36="", menge37="", menge38="", menge39="", menge40="" 
, menge41="", menge42="", menge43="", menge44="", menge45="", menge46="", menge47="", menge48="", menge49="", menge50="" 
, menge51="", menge52="", menge53="", menge54="", menge55="", menge56="", menge57="", menge58="", menge59="", menge60="" 
, menge61="", menge62="", menge63="", menge64="", menge65="", menge66="", menge67="", menge68="", menge69="", menge70="" 
, menge71="", menge72="", menge73="", menge74="", menge75="", menge76="", menge77="", menge78="", menge79="", menge80="" 
, menge81="", menge82="", menge83="", menge84="", menge85="", menge86="", menge87="", menge88="", menge89="", menge90="" 
, menge91="", menge92="", menge93="", menge94="", menge95="", menge96="", menge97="", menge98="", menge99="", menge100=""
};

私の動的フォームが100以上のフィールドを吐き出すまで、私は不幸ですが安全です...「param」/空の変数を設定するコード集約的な方法が上記よりも少ない方法を誰かが知っている場合は、チップインしてください.Thx!

                                         , 
4

2 に答える 2

5

ループで cfparam を実行することの何が問題になっていますか?

<cfset numOfFields = 200>
<cfset fields = "ean,menge">
<cfloop list="#fields#" index="field">
    <cfloop from="1" to="#numOfFields#" index="i">
        <cfparam name="Form.#field##i#" default="">
    </cfloop>
</cfloop>
于 2012-07-04T19:29:11.013 に答える
1

フォーム スコープをループし、フィールド名を解析して関連する入力を見つけます。

以下は、ランダムな値で乱数の入力を生成するサンプル フォームです。

<form name="dynamicForm" action="update.cfm" method="post">
<cfoutput>      
<cfloop from="1" to="#randrange(1,100)#" index="i">
        <br>#i#:<input type="text" name="qty#i#" value="#randrange(1,100)#">    
    </cfloop>
    <br><input type="submit" name="submit" value="submit">
</cfoutput> 
</form>

次に、update.cfm で次の操作を行います。

<cfloop list="#form.fieldnames#" index="fieldname">
    <cfif lcase(left(fieldname,3)) EQ "qty">
        <cfset id = mid(fieldname,4,len(fieldname)) >
        <cfstoredproc 
             procedure="schema.updQTY"
             datasource="myDSN">
             <cfprocparam type="IN" cfsqltype="CF_SQL_INTEGER" value="#id#">
             <cfprocparam type="IN" cfsqltype="CF_SQL_INTEGER" value="#form[fieldname]#">
        </cfstoredproc>
    </cfif>
</cfloop>

個人的には、入力フィールドに「qty_XXX」のような名前を付けて、 と を使用listfirstlistlastてフィールド名を解析しますが、それは純粋な好みです。

于 2012-07-05T13:38:01.227 に答える