使用json数据预加载表单

时间:2013-05-08 14:03:12

标签: javascript jquery html ajax json

我还在学习javascript,jquery以及随之而来的一切。作为一个学习的个人测试我正在开发一个程序,最终将从PHP服务器拉。现在我从硬编码的json文件中提取并使用它预加载页面。然后,用户可以单击已填充的编辑按钮,它将弹出一个带有该部分数据的预加载表单(这是我目前需要帮助的部分)。使用jquery 1.9.1 with migrate和mustache.js和jqmodal来处理表单弹出窗口这是我的代码:

HTML:

 <!DOCTYPE html>
 <html>
 <head>
 <title></title>
 </head>
 <link href='css.css' rel='stylesheet' type='text/css'>
 <script id="playerTpl" type="text/template">
      {{#playerList}}
           <li id="player{{player}}">
                <h3>player: {{player}}</h3>
                <p><strong>Name:</strong> {{name}}</p>
                <p><strong>Score:</strong> {{score}}</p>
                <p><strong>Rank: </strong>{{rank}}</p>
                <a href="" class="editBtn" name="modal">Edit</a>
                <a href="" class="deleteBtn">Delete</a>
          </li>
 {{/playerList}}
 </script>
 <script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
<script src="http://code.jquery.com/jquery-migrate-1.1.1.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/jqModal/r14/jqModal.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/mustache.js/0.7.2/mustache.min.js"></script>

<body>
<div id="mainContent">
    <h1>Prototype Example:</h1>
    <ul id="playersUL">
    </ul>

    <a href="#" id="addBTN">Add Player</a>
    <div class="clear"></div>
    <div class="addplayerStyle" id="addPlayer">
        <form id="myForm">
            <label>Player Number</label>
            <select id="optionList" name="player" required>
                <option value="1">1</option>
                <option value="1">2</option>
                <option value="1">3</option>
                <option value="1">4</option>
            </select><br><br>
            <label>Player Name</label>
            <input type="text" name="name" placeholder="Player Name" required /><br><br>
            <label>Player Score</label>
            <input type="number" name="score" placeholder="Player Score" required /><br><br>
            <label>Player Rank</label>
            <input type="number" name="rank" placeholder="Player Rank" required /><br><br>
            <input type="reset" value="Cancel" class="jqmClose" /><input type="submit" value="Submit" />
            <div class="clear"></div>
        </form>
    </div>
    <script src="script.js"></script>
</div>

</body>

Json文件:

 { 
 "playerList" : [
   {
"player":1,
"name":"Barot Bellingham",
"score":10000,
"rank":5
  },
  {
"player":2,
    "name":"Jonathan G. Ferrar II",
    "score":50,
    "rank":1
   },
   {
"player":3,
    "name":"Hillary Hewitt Goldwynn-Post",
    "score":100000,
    "rank":100
   }
 ]}

最后到目前为止的javascript:

 $(document).ready(function() {

    $.getJSON('data.json', function(data){
        var template = $('#playerTpl').html();
        var html = Mustache.to_html(template, data);
        $('#playersUL').html(html);

        /*for (var i = 0, i <= data.playerList.length, i++) {
            for (key in data.playerList[i].player){
                alert(data.playerList[i].player;
            }
        };*/
        $('#playersUL').on("click", 'a[name=modal]', function(e) {
            e.preventDefault();
            console.log('1');
            /*$.each(data.playerList, function(key, val) {
                console.log(val.player);
                playerArray.push(val);*/
            });//populatePlayerNum();


            $('#addPlayer').jqmShow({
            });
        });
    }); //getJSON

$('#addPlayer').jqm({
    trigger: '#addBTN'
});

 });

最后这样你就可以让弹出窗口正常工作并格式化我拥有css的方式:

 .clear { 
clear: both; 
}
h1 {
margin: 0;
padding: 0;
}
#mainContent {
width: 50%;
margin: 0 auto;
padding: 30px;
background: #0CF;
box-shadow: #666 0 5px 10px;
}
#mainContent h1 {
margin-bottom: 20px;
}
ul { 
float: left; 
margin: 0; 
padding: 0; 
list-style: none; 
}
ul li {
float: left; 
width: auto; 
margin-right: 25px; 
padding: 15px; 
border: 1px solid #666; 
background: #ccc; 
box-shadow: #666 2px 5px 5px;
}
a { 
float: left; 
margin: 5px; 
padding: 5px 10px 5px 10px; 
text-align: center; 
color: #fff; 
text-decoration: none; 
background: #666; 
border: 1px solid #000; 
}
#addBTN { 
}
a:hover { 
background: #009; 
}
form { 
margin-top: 15px; 
}
#addPlayer {     
}
label { 
width: 100px; 
}
 input[type='reset'], input[type='submit'] { 
display: block; 
float: left; 
margin-right: 5px; 
padding: 5px 10px 5px 10px; 
text-align: center; 
color: #fff; 
text-decoration: none; 
background: #666; 
border: 1px solid #000; 
cursor: pointer; 
}
input[type='reset']:hover, input[type='submit']:hover { 
background: #009; 
 }

.addplayerStyle {
display: none;
position: absolute;
top: 50px;
left: 600px;
z-index: 2;
width: 300px;
padding: 20px;
background: #ccc;
border: 1px solid #000;
}

.jqmOverlay { 
background-color: #000; 
}

我希望我现在正在寻找的是什么。我不打算发布到数据库或只是为了将数据添加到表单。我提前感谢您的帮助和感谢。

0 个答案:

没有答案