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