Javascript 表示同一产品3种不同价格的价格数组

Javascript 表示同一产品3种不同价格的价格数组,javascript,jquery,arrays,json,Javascript,Jquery,Arrays,Json,我试图创建一个数组,表示三个不同的商家,他们对同一产品持有不同的价格,后面的代码中显示了这三个商家。 我的逻辑似乎不正确,我想用一个例子来说明如何正确地做到这一点。 附件是我的代码,但请注意商品价格和getRecipeItems部分 JS 好吧,我想我得到了你想要的。以下是两种解决方案: 把所有的东西放在一个地方 函数getRecipeItems{ 返回recipeItems=[ { id:recipe0, // ... 价格:{ 默认值:8, ampm:10, //-哈卡迈尔:12-让我们忽略

我试图创建一个数组,表示三个不同的商家,他们对同一产品持有不同的价格,后面的代码中显示了这三个商家。 我的逻辑似乎不正确,我想用一个例子来说明如何正确地做到这一点。 附件是我的代码,但请注意商品价格和getRecipeItems部分

JS


好吧,我想我得到了你想要的。以下是两种解决方案:

把所有的东西放在一个地方 函数getRecipeItems{ 返回recipeItems=[ { id:recipe0, // ... 价格:{ 默认值:8, ampm:10, //-哈卡迈尔:12-让我们忽略这个 蒂夫塔姆:15, 获取:功能商人{ 返回此[商户]?此[商户]:默认; } } }, // ... ] } // -------------------- //用法 // -------------------- //结果:8默认价格,因为您没有指定商户。 getRecipeItems[0]。price.get; //结果:10。 getRecipeItems[0].price.getampm; //结果:默认值为8,因为您没有设置此值。 getRecipeItems[0].price.gethaCarmel; 商人的魔法计算 您也可以设置默认价格,但将其发送给商家并进行更改

//价格 价格:{ 默认值:8, 获取:功能商人{ 退货商户[商户] ?商户[merchant].getPrice this.default :this.default; } } //商人 商人{ ampm:{ //... getPrice:函数价格{ 退货价格+物品稀有性-折扣+等; } }, // ... }; 在这两种情况下。。。 您应该为商家RecipeItem和RecipeItemPrice创建一个对象。您的代码将更加干净,并且不会在每次创建price时都创建get函数的实例。好吧,你应该对你所有的游戏对象都这么做

//价格 var RecipeItemPrice=函数值。。。{ this.default=值; }; RecipeItemPrice.prototype.get=函数{ //例如,如果您选择第二个选项: 退货商户[商户] ?商户[merchant].getPrice this.default :this.default; };
您好:,您能解释一下这行代码要做什么吗:price:{ampmPrice:Merchantprices[0]。sumPrice,haCarmelPrice:Merchantprices[1]。sumPrice,tivTaamPrice:Merchantprices[2]。sumPrice}。为什么这个数组在函数中?函数getRecipeItems{返回recipeItems=[
var main = function () {

    var recipeType = {
        0: {"name": "cocktail", "ingredients": ["Booz","Roofis","Green Stuff"]},
        1: {"name": "appetizer", "ingredients": ["Some leaves","Some veggies", "I dunno toast","Cheese or whatever"]},
        2: {"name": "main course", "ingredients": ["A dead animal","its blood", "some potatoes","love","asparagus"]} ,
        3: {"name": "dessert", "ingredients": ["Dough","Some Sprinkly shit", "sugar","more sugar","cream shaboogy pop"]} ,
    }

    var Merchantprices = {

        ampm:{"ingredientPrice":recipeType[0].ingredients = 20,"sumPrice":recipeType[0] = ingredientPrice * (recipeType[0].ingredients.length)},
        haCarmel:{},
        tivTaam:{},

    }

    function getRecipeItems() {
        return recipeItems = [
            {
                "id": "recipe0",
                "title": "Grasshopper Cocktail",
                "img": "../images/grasshopper-cocktail.jpg",
                "ingredients": recipeType[0].ingredients,
                "instructions":"shaken not stirred",
                "price": {"ampmPrice":Merchantprices[0].sumPrice,"haCarmelPrice":Merchantprices[1].sumPrice,"tivTaamPrice":Merchantprices[2].sumPrice},
                "type" : recipeType[0].name,
            },
            {
                "id": "recipe1",
                "title": "Beef roast with veggies",
                "img": "../images/beef-roast-with-veggies.JPG",
                "ingredients": recipeType[2].ingredients,
                "instructions":"stuff it good",
                "price": 55,
                "type" : recipeType[2].name,
            },
            {
                "id": "recipe2",
                "title": "Shrimp-Fried-Rice",
                "img": "../images/Shrimp-Fried-Rice.jpg",
                "ingredients": recipeType[1].ingredients,
                "instructions":"extra MSG",
                "price": 65,
                "type" : recipeType[1].name,
            },
            {
                "id": "recipe3",
                "title": "Cupcake from hell",
                "img": "../images/Cupcake-Idea-pics-200x150.png",
                "ingredients": recipeType[3].ingredients,
                "instructions":"death is inevitable",
                "price": 15,
                "type" : recipeType[3].name,
            },
        ]
    }

    function createRecipeItem(recipeItem) {
        var recipeElement = document.createElement('div');
        recipeElement.setAttribute("id", recipeItem.id);
        recipeElement.setAttribute("class", recipeItem);

        recipeDetailsElement = document.createElement("div");
        recipeDetailsElement.setAttribute("id", recipeItem.id+"_details");

        recipeDetailsElement.appendChild(createDeleteRecipe(recipeItem));
        recipeDetailsElement.appendChild(createRecipePic(recipeItem));
        recipeDetailsElement.appendChild(createRecipeTitle(recipeItem));

        recipePreperationElement = document.createElement("div");
        recipePreperationElement.setAttribute("id", recipeItem.id+"_full_details");
        recipePreperationElement.appendChild(createRecipeIngredients(recipeItem));
        recipePreperationElement.appendChild(createRecipeInstructions(recipeItem));
        recipePreperationElement.style.display = 'none';

        recipeDetailsElement.appendChild(recipePreperationElement);


        recipeElement.appendChild(createUndoDeleteRecipe(recipeItem));
        recipeElement.appendChild(recipeDetailsElement);


        return recipeElement;

    }
    function createUndoDeleteRecipe(recipeItem) {
        var undoButton = document.createElement('span');
        undoButton.setAttribute("id", recipeItem.id + "_undo");
        undoButton.setAttribute("class", "fa fa-undo", "aria-hidden", "true");
        $(undoButton).hide();
        $(undoButton).click(() => {
            onItemDeleteUndo(recipeItem);
        });
        return undoButton;
    }
    function createDeleteRecipe(recipeItem) {
        var deleteButton = document.createElement('span');
        deleteButton.setAttribute("class", "fa fa-times-circle", "aria-hidden", "true");

        $(deleteButton).click(() => {
            onItemDelete(recipeItem);
        });

        return deleteButton;
    }

    function onItemDelete(recipeItem) {
        $('#'+recipeItem.id+'_details').hide();
        $('#'+recipeItem.id+'_undo').show();
    }

    function onItemDeleteUndo(recipeItem) {
        $('#'+recipeItem.id+'_details').show();
        $('#'+recipeItem.id+'_undo').hide();
    }

    function createRecipeTitle(recipeItem) {
        var div = document.createElement('div');
        div.innerHTML = recipeItem.title;
        return div;
    }

    function createRecipeInstructions(recipeItem) {
        var div = document.createElement('div');
        div.innerHTML = recipeItem.instructions;
        return div;
    }

    function createRecipePic(recipeItem) {
        var recipePic = document.createElement("img");
        recipePic.setAttribute("src", recipeItem.img);
        recipePic.setAttribute("class", "recipe");
        $(recipePic).css('margin-top', '10px');

        $(recipePic).click(() => {
            $('#'+recipeItem.id+"_full_details").slideToggle();
        });

        return recipePic;
    }

    function createRecipeIngredients(recipeItem) {
        var ingredients = document.createElement("ul");
        ingredients.setAttribute("id", recipeItem.id + "_ingredients");
        ingredients.className = "ingredientsList";

        recipeItem.ingredients.forEach(ingredient => {
            var li = document.createElement("li");
            li.className = "ingredients";
            li.setAttribute("type", "checkbox");

            var checkbox = document.createElement("input");
            checkbox.setAttribute("type", "checkbox");
            li.appendChild(checkbox);

            var ingredientElement = document.createElement("a");
            ingredientElement.innerHTML = ingredient;
            li.appendChild(ingredientElement);

            ingredients.appendChild(li);
        })
        return ingredients;

    }

    recipeItems = getRecipeItems();
    var mainContainer = document.getElementsByClassName('mainContainer');
    recipeItems.forEach(recipeItem => {
        mainContainer[0].appendChild(createRecipeItem(recipeItem));
    });



};
var recipeItems;
var Merchantprices;
$(document).ready(main);