-1

私はPHPを使用して、フォーム内のいくつかのフィールドを動的に生成しています(これは完全なコードhttp://jsfiddle.net/KBYC5/1/のjsFiddleです)。

<?php 
            $contacts= array('CONTRACT MANAGER', 'MEDICAL DIRECTOR', 'UTILIZATION MANAGER', 'QUALITY IMPROVMENT MANAGER ', 'CHIEF MEDICAL DIRECTOR', 'CMO', 'AUTHORIZATION MANAGER', 'CUSTOMER SERVICE MANAGER');
            foreach ($contacts as $contact) //TODO add something to check if contact already exists and don't show checkbox if it does
            {
                echo "<li>
                        <label>" . ucwords(strtolower($contact)) . "</label>" . inp_return('contact[]', 45) . " <input type='hidden' value='$contact' name='title' /> 
                        <ul>
                            <li><label> Rating: </label>" .  inp_return('rating[]',3) . "</li>
                            <li><label>Phone: </label>" . inp_return('contact_phone[]',13, 'phone'). "</li>
                            <li><label>Ext: </label>" . inp_return('ext[]', 8) . "</li>
                            <li><label>Create Referral Contact</label> " . cbox_return('create_contact[]') . "</li> 
                        </ul>
                        <div class='clear'></div>
                    </li>
                ";
            }
        ?>

ご覧のとおり、それぞれに$contactsの値を含む非表示の入力があります。次に、jQueryを使用して非表示の入力フィールドの値を確認し、それをJSONオブジェクトの「title」プロパティと比較して、同じ場合はすべてのフォーム値を入力します。 。私のスクリプトセクションはここにあります:

<script type='text/javascript'>
var contacts = $.parseJSON('[{"id":1,"name":"TEST CONTACT","title":"CONTRACT MANAGER","rating":5,"phone":"(000)000-0000","ext":"1111","rfcode":"0000"},
{"id":2,"name":"TEST2 CONTACT","title":"MEDICAL DIRECTOR","rating":2,"phone":"(111)111-1111","ext":"2222","rfcode":"0000"}]');
$(document).ready(function () {$("#contracting_info ul li").each(function (){
    for (var i in contacts)
        {
            alert($(this).children("input[name='title']").val()); die;
            var title = contacts[i].title
            if (title == $(this).children("input[name='title']").val())
                alert('made it here');
        }
    });
});

各リストアイテムのcontact[]要素にJSON配列の値(titleが非表示のtitle要素と一致する場合)をロードするにはどうすればよいですか?たとえば、契約マネージャーのcontact[]フィールドにTESTCONTACTを含める必要があります。

4

1 に答える 1

0

これが私の問題のために働いたスクリプトセクションです。

<script type='text/javascript'>
var contacts = $.parseJSON('<?php echo json_encode(sql::results("SELECT * FROM crm.dbo.managed_care_contacts where rfcode =" . hexstr($referral->get_id())));?>');
$(document).ready(function () {

    $("#contracting_info li").each(function (){
        for (var i in contacts)
        {
            alert(contacts[i].title + ' ' + $(this).children("input[name='title']").val());
            var title = contacts[i].title
            if (title == $(this).children("input[name='title']").val())
                {
                        $(this).children("input[name='contact[]']").val(contacts[i].name);
                        $(this).find("input[name='contact_phone[]']").val(contacts[i].phone);
                        $(this).find("input[name='ext[]']").val(contacts[i].ext);
                        $(this).find("input[name='rating[]']").val(contacts[i].rating);


                }
        }
    });//close .each (for autofilling form
});

</script>

残念ながら、これは、各リストアイテム要素をループしてから、すべての連絡先をループする必要があることを意味します(したがって、各liの連絡先をループすることになります)。ただし、正常に動作しています。

うまくいけば、これは、フォームフィールドにjsonオブジェクト(フォームフィールドが配列に投稿する場所)からの情報を動的に入力しようとしている他の誰かに役立つことを願っています。

于 2012-10-23T23:00:45.957 に答える