Передать объект "элемент" в класс - PullRequest
0 голосов
/ 17 марта 2019

У меня есть два класса в отдельных модулях «проект» и «галерея». Один класс предназначен для объекта, в котором хранятся данные об одном проекте, а другой - для объекта, в котором хранятся все проекты.

Я пытаюсь передать объект "element" объекту "gallery", сохранить его в конструкторе, а затем использовать методы on для перехода к объекту "project".

РЕДАКТИРОВАТЬ 2: Мой код:

gallery.js:

import {project} from './project.js';


class gallery
{
constructor(selector)
{      
    this.projects = [];
    let parent = document.createElement("div");
    Object.assign(this, parent);
    this.parent = selector;

}

AddProject(name, imgsrc, desc, tags)
{
    const temp = new project(name,imgsrc,desc,tags);
    this.projects.push(temp);
}

PrintCallback(currentValue, index, arr)
{
    currentValue.PrintImage(this.parent);
}

PrintGallery()
{
    this.projects.forEach(this.PrintCallback);
}
}

document.addEventListener("DOMContentLoaded", function(event) {

let gallerySelector = document.querySelector("#portfolio-gallery");

const grafika = new gallery(gallerySelector);

grafika.AddProject("aaa","logo.png","qwerty",['aaa']);
grafika.AddProject("aaa","baner.png","aaa",['aaa']);
grafika.AddProject("aaa","kolo.png","aaa",['aaa']);
grafika.AddProject("aaa","plakietka.png","aaa",['aaa']);
grafika.AddProject("aaa","stark.png","aaa",['aaa']);
grafika.AddProject("aaa","targaryen.png","aaa",['aaa']);
grafika.AddProject("aaa","plakat.png","aaa",['aaa']);

grafika.PrintGallery();

});

project.js:

export class project
{
constructor(name,img,desc,tags)
{
    this.name = name;
    this.desc = desc;
    this.imgsrc = img;
    this.tags = tags;
}

CreateDiv(code,cssClass)
{
    const template = document.createElement("div");
    template.innerHTML = code;
    template.classList.add(cssClass);
    return template;
}

PrintDesc(selector)
{       
    let parent = document.createElement('div');
    parent = selector;

    const content = 
'<h1>'+this.name+'</h1>'+'<p>'+this.desc+'</p>'+'<h4>'+this.tags.join(", 
")+'</h4>'
    const content_div = this.CreateDiv(content,"project-content");

    parent.appendChild(content_div);

}

PrintImage(selector)
{    
    let parent = document.createElement('div');
    parent = selector;

    const img = '<img  src="grafika/'+this.imgsrc+'">';
    const img_div = this.CreateDiv(img,"project-img");
    img_div.classList.add("tile");

    parent.appendChild(img_div);

    $(parent).hide();
    $(parent).fadeIn(500);
}
};
...