Попытка получить доступ к контенту json и отобразить его в виде сетки - PullRequest
0 голосов
/ 09 января 2019

У меня есть файл JSON со следующим содержимым.

{
    "rooms":[
      {
        "id": "1",
        "name": "living",
        "Description": "The living room",
         "backgroundpath":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSrsU8tuZWySrSuRYdz72WWFiYaW5PCMIwPAPr_xAIqL-FgmQ4qRw",       
         "Settings": {
          "Sources": [
            {
              "srcname":["DirectTV","AppleTV","Sonos"],
              "iconpath":["src/assets/images/ThemeEditorImgLib_iTVLight5d3a46c1ad5d7796.png","path2"]
            }
            ],
          "hex": "#000"
          }
      },
      {
        "id": "2",
        "name": "dining",
        "Description": "The Dining room",
        "backgroundpath":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTjjspDkQEzbJJ1sSLS2ReWEx5P2ODNQmOtT572OIF9k3HbTGxV",
        "Settings": {
          "Sources": [
            {
              "srcname":["Climate","Shades"],
              "iconpath":["path1","path2"]
            }
            ],
          "hex": "#000"
        }
      }
]
}

Мой HTML-файл имеет:

<div class="roww">
<div class="col-md-4 col-sm-6 col-12">

</div>
 </div>

Я хочу отобразить содержимое JSON в HTML. До сих пор я пробовал следующее.

private initTileGrid():void
  {

    var col = document.getElementsByClassName("roww")[0];

    var outeritems=this.room_list.rooms;
   // console.log(outeritems);
    for(var i=0;i<outeritems.length;i++){
      var tile = document.getElementsByClassName("col-md-4 col-sm-6 col-12 tile no-padding")[0];
     var outerdiv = document.createElement("div");
      var h5 = document.createElement("h5");
      h5.innerHTML = outeritems[i].Description;
      outerdiv.appendChild(h5);
      var p = document.createElement("p");
      p.innerHTML = outeritems[i].name;
      outerdiv.appendChild(p);
     // col.appendChild(outerdiv);
      tile.appendChild(outerdiv);
      var inneritem=outeritems[i].Settings.Sources.srcname;
      console.log(inneritem);
      var innerdiv = document.createElement("div");
      for(var j=0;j<inneritem.length;j++)
      {
        console.log("hi")
        var h5inner = document.createElement("h5");
        h5inner.innerHTML = inneritem.srcname; 
        console.log(h5inner);
        innerdiv.appendChild(h5inner);
      }
tile.appendChild(innerdiv);
    }

Я могу отобразить описание и имя из json, но не могу получить список источников.

Мое окончательное решение должно быть сеткой с числом плиток, равным количеству объектов в JSON, при этом каждая плитка имеет фоновое изображение из json и его содержимое.

Кто-нибудь может сказать мне, где я иду не так? Любая помощь приветствуется!

Ответы [ 4 ]

0 голосов
/ 09 января 2019

V_Stack, как уже говорилось, это всего лишь настройка, которую я хотел бы сделать с разделом источников JSON, продвигаясь вперед, это облегчит работу с источником, особенно если вы добавите дополнительные свойства. Обратите внимание, что теперь это массив автономных объектов.

{
  "rooms": [{
      "id": "1",
      "name": "living",
      "Description": "The living room",
      "backgroundpath": "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSrsU8tuZWySrSuRYdz72WWFiYaW5PCMIwPAPr_xAIqL-FgmQ4qRw",
      "Settings": {
        "Sources": [{
            "srcname": "DirectTV",
            "iconpath": "src/assets/images/ThemeEditorImgLib_iTVLight5d3a46c1ad5d7796.png"
          },
          {
            "srcname": "AppleTV",
            "iconpath": "path2"
          },
          {
            "srcname": "Sonos",
            "iconpath": ""
          }
        ],
        "hex": "#000"
      }
    },
    {
      "id": "2",
      "name": "dining",
      "Description": "The Dining room",
      "backgroundpath": "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTjjspDkQEzbJJ1sSLS2ReWEx5P2ODNQmOtT572OIF9k3HbTGxV",
      "Settings": {
        "Sources": [{
            "srcname": "Climate",
            "iconpath": "path1"
          },
          {
            "srcname": "Shades",
            "iconpath": "path2"
          }
        ],
        "hex": "#000"
      }
    }
  ]
}
0 голосов
/ 09 января 2019

Ваша основная проблема начинается с этой строки var inneritem=outeritems[i].Settings.Sources.srcname; Sources - это массив, поэтому вам необходимо получить к нему доступ, например Sources[j], где j - число в пределах длины массивов.

Внутренний цикл в порядке, вам просто нужно правильно пройти через Sources

Мне также пришлось добавить классы в класс плиток, чтобы соответствовать вашему getElementsByClassName запросу

const room_list = {
  "rooms": [{
      "id": "1",
      "name": "living",
      "Description": "The living room",
      "backgroundpath": "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSrsU8tuZWySrSuRYdz72WWFiYaW5PCMIwPAPr_xAIqL-FgmQ4qRw",
      "Settings": {
        "Sources": [{
          "srcname": ["DirectTV", "AppleTV", "Sonos"],
          "iconpath": ["src/assets/images/ThemeEditorImgLib_iTVLight5d3a46c1ad5d7796.png", "path2"]
        }],
        "hex": "#000"
      }
    },
    {
      "id": "2",
      "name": "dining",
      "Description": "The Dining room",
      "backgroundpath": "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTjjspDkQEzbJJ1sSLS2ReWEx5P2ODNQmOtT572OIF9k3HbTGxV",
      "Settings": {
        "Sources": [{
          "srcname": ["Climate", "Shades"],
          "iconpath": ["path1", "path2"]
        }],
        "hex": "#000"
      }
    }
  ]
}

var col = document.getElementsByClassName("roww")[0];

var outeritems = room_list.rooms;
// console.log(outeritems);
for (var i = 0; i < outeritems.length; i++) {
  var tile = document.getElementsByClassName("col-md-4 col-sm-6 col-12 tile no-padding")[0];
  var outerdiv = document.createElement("div");
  var h5 = document.createElement("h5");
  h5.innerHTML = outeritems[i].Description;
  outerdiv.appendChild(h5);
  var p = document.createElement("p");
  p.innerHTML = outeritems[i].name;
  outerdiv.appendChild(p);
  // col.appendChild(outerdiv);
  tile.appendChild(outerdiv);
  var inneritems = outeritems[i].Settings.Sources
  var innerdiv = document.createElement("div");
  for (var j = 0; j < inneritems.length; j++) {
    var inneritem = inneritems[j];
    var h5inner = document.createElement("h5");
    h5inner.innerHTML = inneritem.srcname;
    innerdiv.appendChild(h5inner);
  }
  tile.appendChild(innerdiv);
}
<div class="roww">
  <div class="col-md-4 col-sm-6 col-12 tile no-padding">

  </div>
</div>
0 голосов
/ 09 января 2019

Попробуйте это:

var col = document.getElementsByClassName("roww")[0];

var outeritems = this.room_list.rooms;
// console.log(outeritems);
for (var i = 0; i < outeritems.length; i++) {
  var tile = document.getElementsByClassName("col-md-4")[0];
  var outerdiv = document.createElement("div");
  var h5 = document.createElement("h5");
  h5.innerHTML = outeritems[i].Description;
  outerdiv.appendChild(h5);
  var p = document.createElement("p");
  p.innerHTML = outeritems[i].name;
  outerdiv.appendChild(p);
  // col.appendChild(outerdiv);
  tile.appendChild(outerdiv);
  outeritems[i].Settings.Sources.forEach(source => {

    var inneritem = source.srcname;
    console.log(inneritem);
    var innerdiv = document.createElement("div");
    for (var j = 0; j < inneritem.length; j++) {
      console.log("hi")
      var h5inner = document.createElement("h5");
      h5inner.innerHTML = inneritem[j];
      console.log(h5inner);
      innerdiv.appendChild(h5inner);
    }
    tile.appendChild(innerdiv);
  });
}

}

Вам нужно перебрать Settings.Sources и имя srcname, потому что все они являются массивами

0 голосов
/ 09 января 2019

Я бы предложил и рекомендовал создать ваш динамический HTML следующим образом с литералами шаблона .

Использование Array # map , Array # join и Разрушающее присвоение

const data = {"rooms":[{"id":"1","name":"living","Description":"The living room","backgroundpath":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSrsU8tuZWySrSuRYdz72WWFiYaW5PCMIwPAPr_xAIqL-FgmQ4qRw","Settings":{"Sources":[{"srcname":["DirectTV","AppleTV","Sonos"],"iconpath":["src/assets/images/ThemeEditorImgLib_iTVLight5d3a46c1ad5d7796.png","path2"]}],"hex":"#000"}},{"id":"2","name":"dining","Description":"The Dining room","backgroundpath":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTjjspDkQEzbJJ1sSLS2ReWEx5P2ODNQmOtT572OIF9k3HbTGxV","Settings":{"Sources":[{"srcname":["Climate","Shades"],"iconpath":["path1","path2"]}],"hex":"#000"}}]}

const res = data.rooms.map(({name, Description, Settings:{Sources}})=>{
  
  const inner = Sources.map(({srcname})=>{
    return srcname.map(src=>`<h5>${src}</h5>`).join("");
  }).join("");

  return `
    <div>
      <h5>${Description}</h5>
      <p>${name}</p>
      <div class="inner">
         ${inner}
      </div>
    </div>
  `
}).join("");

document.body.innerHTML = res;
body>div{background-color:lightgrey;padding:5px;margin-top:5px}body>div::before{content:"row"}body>div>*{margin-left:10px}h5{background-color:blue;color:white;padding:5px}h5::before{content:"outer h5:: "}p{background-color:purple;color:white;padding:5px}p::before{content:"p:: "}div.inner{padding:5px;background-color:grey}div.inner::before{content:"inner div"}div.inner>h5{background-color:green;color:white}div.inner>h5::before{content:"inner h5:: "}

Unminified CSS:

body > div {
  background-color: lightgrey;
  padding: 5px;
  margin-top: 5px;
}

body > div::before {
  content: "row";
}

body > div > * {
  margin-left: 10px;
}

h5 {
  background-color: blue;
  color: white;
  padding: 5px;
}

h5::before {
  content: "outer h5:: "
}

p {
  background-color: purple;
  color: white;
  padding: 5px;
}

p::before {
  content: "p:: ";
}

div.inner {
  padding: 5px;
  background-color: grey;
}

div.inner::before {
  content: "inner div";
}

div.inner > h5 {
  background-color: green;
  color: white;
}

div.inner > h5::before {
  content: "inner h5:: "
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...