以前,在将JSON数据导入到表中时已获得帮助,但是这次我们需要一种灵敏且灵活的布局,并且正在使用网格,div,p和CSS样式化方法。
我们正在显示最新会员的缩略图“卡片”,以加入/更新我们的组成员身份-卡片的数量可以在2-6之间变化,一次可以显示,并且可以经常更改
当用户访问网页时,我们希望JSON数据用缩略图卡填充灵活的响应式网格。
卡数据来自格式正确的JSON文件,该文件由第三方应用程序创建并上传到网站。
需要使用的数据是:
<style type="text/css" media="all">
.newmembers {
display: grid;
grid-gap: 10px;
grid-template-columns: repeat(auto-fit, minmax(155px,175px));
grid-auto-rows: 370px;
grid-auto-flow: dense;
justify-content: center;
padding: 10px 10px 10px;
background-color: #c7c7c7;
}
.member {
background: rgba(255, 213, 70, 0.3);
border: 1px solid grey;
text-align: center;
border-radius: 4px;
box-shadow: 3px 3px 3px grey;
}
.type {
color: #1f7665;
font-weight: 900;
text-transform: uppercase;
margin: 5px 5px 0px;
text-align: center;
}
.year {
color: #1f7665;
font-weight: bold;
font-size: x-small;
margin: 0px 0px 0px;
text-align: center;
}
.thumb {
width: 85%;
min-height: 160px;
max-height: 160px;
min-width: 160x;
max-width: 160px;
object-position: center top;
-o-object-fit: cover;
object-fit: cover;
overflow: hidden;
border: 5px solid #fff;
border-radius: 4px;
box-shadow: 5px 5px 5px grey;
-webkit-filter: grayscale(100%);
filter: grayscale(100%);
}
.thumb:hover {
position:relative;
top:5px;
left:5px;
background:#00CCCC;
-webkit-filter: grayscale(10%);
filter: grayscale(10%);
}
.membername {
color: #1f7665;
font-weight: 900;
text-transform: uppercase;
margin: 10px 0px 0px;
}
.group {
color: #333333;
font-weight: bold;
margin: 0px 0px 5px;
}
.company {
color: #333333;
font-weight: normal;
margin: 0px 0px 5px;
}
.classification {
color: #333333;
font-weight: bold;
margin: 0px 0px 10px;
font-size: x-small;
}
.info {
margin: 10px;
}
</style>
<div class="newmembers">
<!-- We want to populate a div like this 3,4,5 or 6 times with data from the correctly formated JSON file -->
<div class="member">
<p class="type">* RENEWING *</p>
<p class="year">Year: THREE</p>
<a class="memurl" href="https://example.com/brownsville.html#59e5c8">
<img class="thumb"
alt="MEMBER PROFILE: Andy Smith - Smithville, Andys Lawns, Gardening"
title="MEMBER PROFILE:
Andy Smith
Smithvile
Andys Laws
Gardening"
src="https://example.com/brownsville.html/u/#59e5c8.jpg"
>
</a>
<p class="info">
<p class="membername">Andy Smith</p>
<p class="group">Smithville</p>
<p class="company">Andys Lawns</p>
<p class="classification">Gardening</p>
</p>
</div>
<!-- We want to populate a div like this 3,4,5 or 6 times with data from the correctly formated JSON file -->
<div class="member">
<p class="type">* RENEWING *</p>
<p class="year">Year: FOUR</p>
<a class="memurl" href="https://example.com/brownsville.html#5a2f86">
<img class="thumb"
alt="MEMBER PROFILE: Dave Brown - Brownville, Daves Paint, Paint"
title="MEMBER PROFILE:
Dave Brown
Brownville
Daves Paint
Paint"
src="https://example.com/u/5a2f86.jpg"
>
</a>
<p class="info">
<p class="membername">Dave Brown</p>
<p class="group">Brownsville</p>
<p class="company">Daves Paint</p>
<p class="classification">Paint</p>
</p>
</div>
<!-- more "member" divs here -->
</div>
我们的JSON文件如下所示,但可以更改为所需的任何内容:
[
{ "type":"* RENEWING *", "year":"THREE", "memurl":"https://example.com/smithville.html#5a2f81", "memimgsrc":"https://example.com/smithville.html/u/#59e5c8.jpg", "membername":"Andy Smith","group":"Smithville","company":"Andys Lawn","classification":"Gardening" },
{ "type":"* RENEWING *", "year":"FOUR", "memurl":"https://example.com/brownsville.html#5a2f86", "memimgsrc":"https://example.com/brownsville.html/u/#5a2f86.jpg", "membername":"Dave Brown","group":"Brownsville","company":"Daves Paint","classification":"Paint" },
{ "type":"* NEW *", "year":"ONE", "memurl":"https://example.com/applegate.html#5b3a51", "memimgsrc":"https://example.com/applegate.html/u/#5b3a51.jpg", "membername":"May Apple","group":"Applegate","company":"Marys Conserves","classification":"Canning" }
];
我们已经使用以下脚本将数据导入到表中,但是如何将其与上面的示例配合使用?
<!-- We have used this load to populate a table from JSON and it works perfect -->
<script>
//first add an event listener for page load
document.addEventListener( "DOMContentLoaded", get_json_data, false ); // get_json_data is the function name that will fire on page load
//this function is in the event listener and will execute on page load
function get_json_data(){
// Relative URL of external json file
var json_url = 'example.json';
//Build the XMLHttpRequest (aka AJAX Request)
xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {//when a good response is given do this
var data = JSON.parse(this.responseText); // convert the response to a json object
append_json(data);// pass the json object to the append_json function
}
}
//set the request destination and type
xmlhttp.open("POST", json_url, true);
//set required headers for the request
xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
// send the request
xmlhttp.send(); // when the request completes it will execute the code in onreadystatechange section
}
// FUNCTION TO ADD OR CREATE "member" DIVS NEEDS TO HERE
//need function to add json data to the div 'newmembers' and make new div?
// No idea
function append_json(data){
var member = document.getElementById('newmembers');
data.forEach(function(object) {
NOT SURE WHAT TO PUT HERE
});
}
</script>
帮助会很棒,如果需要其他信息或说明,请告诉我。
答案 0 :(得分:3)
您已经很接近了,您可以将硬编码的内容用作模板。
我们将模板保留为HTML,您真的要更改布局布局的JavaScript吗?
我已经删除了ajax逻辑,因为您应该拥有的一切都很好。
我还为您提供了alt
和title
属性的一些工作,但是您应该有足够的工作空间。
var postData = [{
"type": "* RENEWING *",
"year": "THREE",
"memurl": "https://example.com/smithville.html#5a2f81",
"memimgsrc": "https://example.com/smithville.html/u/#59e5c8.jpg",
"membername": "Andy Smith",
"group": "Smithville",
"company": "Andys Lawn",
"classification": "Gardening"
},
{
"type": "* RENEWING *",
"year": "FOUR",
"memurl": "https://example.com/brownsville.html#5a2f86",
"memimgsrc": "https://example.com/brownsville.html/u/#5a2f86.jpg",
"membername": "Dave Brown",
"group": "Brownsville",
"company": "Daves Paint",
"classification": "Paint"
},
{
"type": "* NEW *",
"year": "ONE",
"memurl": "https://example.com/applegate.html#5b3a51",
"memimgsrc": "https://example.com/applegate.html/u/#5b3a51.jpg",
"membername": "May Apple",
"group": "Applegate",
"company": "Marys Conserves",
"classification": "Canning"
}
];
function append_json(data) {
//Set Up the template
var s = $("#postTemplate")[0].innerHTML.trim();
var holder = document.createElement('div');
holder.innerHTML = s;
var template = holder.childNodes;
var member = document.getElementById('newmembers');
data.forEach(function(object) {
//Clone Template
var newItem = $(template).clone();
//Populate it
$(newItem).find(".type").html(object.type);
$(newItem).find(".year").html($(newItem).find(".year").html() + " " + object.year);
$(newItem).find(".memurl").attr("href", object.memurl);
var img = $(newItem).find(".thumb")
$(img).attr("src", object.memimgsrc).attr("alt", $(img).attr("alt") + object.membername + " " + "etc")
.attr("title", $(img).attr("title") + object.membername + " finish this off");
$(newItem).find(".membername").html(object.membername);
$(newItem).find(".group").html(object.group);
$(newItem).find(".company").html(object.company);
$(newItem).find(".classification").html(object.classification);
//Append it
$(".newmembers").append(newItem);
});
}
$("document").ready(function() {
append_json(postData);
});
.newmembers {
display: grid;
grid-gap: 10px;
grid-template-columns: repeat(auto-fit, minmax(155px, 175px));
grid-auto-rows: 370px;
grid-auto-flow: dense;
justify-content: center;
padding: 10px 10px 10px;
background-color: #c7c7c7;
}
.member {
background: rgba(255, 213, 70, 0.3);
border: 1px solid grey;
text-align: center;
border-radius: 4px;
box-shadow: 3px 3px 3px grey;
}
.type {
color: #1f7665;
font-weight: 900;
text-transform: uppercase;
margin: 5px 5px 0px;
text-align: center;
}
.year {
color: #1f7665;
font-weight: bold;
font-size: x-small;
margin: 0px 0px 0px;
text-align: center;
}
.thumb {
width: 85%;
min-height: 160px;
max-height: 160px;
min-width: 160x;
max-width: 160px;
object-position: center top;
-o-object-fit: cover;
object-fit: cover;
overflow: hidden;
border: 5px solid #fff;
border-radius: 4px;
box-shadow: 5px 5px 5px grey;
-webkit-filter: grayscale(100%);
filter: grayscale(100%);
}
.thumb:hover {
position: relative;
top: 5px;
left: 5px;
background: #00CCCC;
-webkit-filter: grayscale(10%);
filter: grayscale(10%);
}
.membername {
color: #1f7665;
font-weight: 900;
text-transform: uppercase;
margin: 10px 0px 0px;
}
.group {
color: #333333;
font-weight: bold;
margin: 0px 0px 5px;
}
.company {
color: #333333;
font-weight: normal;
margin: 0px 0px 5px;
}
.classification {
color: #333333;
font-weight: bold;
margin: 0px 0px 10px;
font-size: x-small;
}
.info {
margin: 10px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div class="newmembers">
<!-- Template for our posts -->
<script type="text/template" id="postTemplate">
<div class="member">
<p class="type"></p>
<p class="year">Year:</p>
<a class="memurl" href="">
<img class="thumb" alt="MEMBER PROFILE: " title="MEMBER PROFILE: " src="">
</a>
<!-- Replaced p with div, can't nest p tags -->
<div class="info">
<p class="membername"></p>
<p class="group"></p>
<p class="company"></p>
<p class="classification"></p>
</div>
</div>
</script>
</div>