- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
已编辑
设法让大部分工作正常运行,但最后遇到了问题。
我有一个 html 文件,其中包含一些输入字段和 div 元素,我必须在创建该文件时附加一个配方。
因此,我在模块中分离了两个类 - 食谱和书籍,以及一个 app.js 文件,然后应将两者合并到一个工作应用程序中。
我现在遇到的问题是,每当我单击“添加”按钮时,菜谱仅显示一毫秒,然后就消失了..我不知道为什么。难道是因为我的类是自调用的?我尝试以标准方式执行此操作,但由于某种原因运行 x instanceof y
总是返回 false。我上传了一个短视频,直观地展示了该问题。
此外,当我尝试将对象 r 插入书本后调用 book.getRecipes() 时,我得到 [object Object] 而不是 r 中包含的值。
如果需要,可以提供更多信息。
谢谢
var Recipe = (function() {
var nextId = 1;
var constr = function(name, rating, image, category) {
this._id = nextId++;
this._name = name || '';
this._rating = rating || '';
this._image = image || '';
this._category = category || '';
this.setName = function(name) {
this._name = name;
};
this.setRating = function(rating) {
this._rating = rating;
};
this.setImage = function(image) {
this._image = image;
};
this.setCategory = function(category) {
this._category = category;
};
};
return constr;
})();
还有
var Book = (function() {
var construct = function(recipes) {
this._recipes = recipes || [];
this.addRecipe = function(recipe) {
this._recipes.push(recipe);
};
this.removeRecipe = function(id) {
this._recipes.splice(id, 1);
};
this.getRecipes = function() {
return this._recipes;
};
};
return construct;
})();
app.js 已全部初始化(loadData 函数是预先编写的(不是我写的!)):
var app = app || {};
(function(recipeBook) {
var book = new Book();
var r = new Recipe();
$('#add_book').click(function () {
var $name = $('.uk-form').find('#name').val();
var $rating = $('.uk-form').find('#rating').val();
var $image = $('.uk-form').find('#image').val();
var $category = $('.uk-form').find('#category :selected').val();
r._name = $name;
r._rating = $rating;
r._image = $image;
r._category = $category;
book.addRecipe(r);
//trying add a recipe into the book
loadData();
});
$("#clear_book").click(function() {
(".uk-form").reset();
console.log('clears recipe form');
});
$(document).on('click','.remove',function(ev){
// still not implemented
console.log('remove target recipe by Id');
loadData();
});
loadData();
function loadData() {
var meat = book.getRecipes().filter(function(r) {
return r._category === "meat";
});
var vegan = book.getRecipes().filter(function(r) {
return r._category === "vegan";
});
var dessert = book.getRecipes().filter(function(r) {
return r._category === "dessert";
});
var source = $("#recipe-trmplate").html();
var template = Handlebars.compile(source);
var contextMeat = {meat:meat};
var contextvegan = {meat:vegan};
var contextdessert = {meat:dessert};
var html = template(contextMeat);
var html2 = template(contextvegan);
var html3 = template(contextdessert);
$('#meat_recipes').html(html);
$('#vegan_recipes').html(html2);
$('#dessert_recipes').html(html3);
}
}(app));
app.js 大部分是由另一个人预先编写的,我在其中的工作是添加 DOM 操作(添加/删除书籍等)
最佳答案
您的点击处理程序中似乎有一个额外的 } 。可能是一个错字。令人困惑的是,您将书 ctor 命名为“书”,然后又对书的实例使用相同的名称。需要向 book 构造函数传递一个数组以分配给其 _recipes 属性。你可以这样做
`this._recipes = recipes || [];
撇开这些繁琐的事情不谈,我不确定是什么让你感到困惑。您需要从 HTML 中获取数据,可能使用 jQuery 和诸如
之类的语句`var name = $('input selector string').val()`
or possibly
`var rating = $('div selector string').html()'
等等...
然后使用这些值调用您的配方构造函数
最后将其添加到您的书中作为 book.add( newRecipe )
关于javascript - JS 应用程序自动刷新/元素消失编辑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40811554/
我使用 vanilla JS 通过 AJAX 向数据库发送请求。数据写入数据库没有问题。在刷新页面之前,我看不到被放入数据库中的内容。当我删除内容时也会发生同样的情况,我必须刷新才能看到内容消失了。
抱歉,这篇文章很长,我试图提供所有信息并解释我已经尝试过的内容。 问题: 我将经典的 Phoenix View 放入实时 View 中。虽然一切看起来都很好,但 echart 一完成绘制就消失了。好像
搜索了一下,没有找到我要找的东西。我有两个按钮,单击一次即可拉出两个不同的选择框,第二次单击它们就会消失。但是,我希望选择框 1 在单击按钮 2 时消失,反之亦然:选择框 2 将在单击按钮 1 时消失
我正在尝试使用自动布局使用“浮动”标题构建滚动视图。更确切地说,我正在尝试建立包含几列的日历视图。这些列中的每个列都应具有自己的标题,该标题应浮动在顶部,而该列可以垂直滚动到其下方。 如果一切正常,则
我正在尝试模仿星星背景。 星星是在加载时创建并随机散布在整个网站上的。到目前为止我已经调整了一些代码。 var star="•"; var numStars=100; for(var x=1;x•";
我查遍了整个网络,但找不到解决方案。我对 jQuery 也很陌生。 我的案例: 我有一个导航栏,其中的每个链接都会激活/触发一个megamenu(每个链接都有自己的megamenu)。 我需要什么:
我有一个可扩展的 ListView ,当我点击一行时,它会触发 onChildClick 或 onGroupClick,具体取决于我点击的是子项还是组。 如果我在 xml 布局文件中添加可点击的内容(
在我的程序中,我有一个 NSMutableData 变量,用于收集来自 http://www.nhara.org/scored_races-2013.htm 的信息。 .大约第三次从网站获取信息后,当
我一直在完美地使用 Genymotion,但是从最近几天开始我的 Genymotion 并打开它的 GPS 开始,我的 Genymotion 突然消失了。但是我的 eclipse 显示 Genymot
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
所以我的 Item::return_all() 有问题,因为我在 main.cpp 中调用它。早些时候我在 read_file() 和 for (auto data : example_item) 中
所有 UITableCells 在 UITableView 中滚动和触摸时消失。一切都以编程方式完成,我使用标准的 UITableViewCell 类。 我在某处读到包含我的单元格数据的数组可能被清空
我对 Swift 还很陌生。我的问题是我的 UICollectionView 正在消失。在 Xcode 中,它显示一切就绪,但当我在模拟器或设备上启动时,它消失了,只剩下导航栏和标签栏。 有谁知道是什
这是 this one的续题。较早的问题是在复选框上。但是后来我根据要求把check box改成了radio buttons。 现在我需要显示子单选按钮并在母单选按钮处于事件状态时更改背景颜色。一旦它
我用 JS 写了一个简单的脚本。当我将它放入 html 文档(在 body 标签的底部)时,它工作正常。当我尝试将它放入外部文档并链接它时,脚本运行但 canvas 元素消失(刚刚检查:当我将脚本放在
我正在尝试创建一个带有固定元素的滚动页面,当用户向下滚动页面时,该元素“始终”可见。例如,带有道路背景的汽车图像。因此,当用户向下滚动页面时,汽车看起来就像在路上行驶。虽然汽车出现在道路的顶部,但它必
这个问题在这里已经有了答案: How can I change CSS display none or block property using jQuery? (15 个答案) 关闭 4 年前。
我在市场上有一个支持小部件的应用程序。我对应用程序进行了一些重大更改,重新设计了很多内部结构,替换/重命名 Activity 等。其他更改包括从不同的共享首选项键获取小部件配置数据,尽管我已经编写了转
我有一个 fragment alertsfragment.java,它有一个 GridView 布局,当我打开它时,它工作正常,但是当我在其他选项卡之间滑动时,它就消失了。为了解释更多,我有一个 Ac
我是一名优秀的程序员,十分优秀!