- 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/
我想做的是,如果鼠标位于“下一个”按钮上,它会以慢速向右滚动,如果鼠标没有位于“下一个”按钮上,它会停止滚动? 这是我的尝试http://jsfiddle.net/mdanz/nCCRy/14/ $(
StyleCop 是一个很棒的视觉工作室小插件。但它不会向您显示实时提示或提供任何自动修复。 随之而来的是 reSharper 和 StyleCop for reSharper,这是理想的解决方案,但
我为我的MatchQuery使用了模糊性选项,但是我想将模糊性值设置为auto。有什么办法吗? 另外,对于完成建议程序,您可以将其设置为支持unicode,对于我的MatchQuery,有什么方法可以
我想从表中获取一行[字符串名称,字符串密码,int 某些内容]并将其映射到一个 User 对象,该对象具有 3 个属性,如上面的 getter 和 setter有什么方法可以自动完成吗?我考虑过反射,
我有一个像这样的方法:void m1(string str) 并且有一个像这样的类: public class MyClass { public bool b1 { set; get; }
我正在尝试使用 $rootScope 从一个 Controller 向另一个 Controller $broadcast 一些数据。 如果我使用像 ng-click 这样的触发器来运行将广播的功能,它
我考虑了很多关于是要使用完全自动化的缓存还是手动缓存。 我们的自动方法是一种解决方案,它可以挖掘数据库、查询和格式化每个潜在和 future 的数据请求,并将其保存到适当的缓存存储(内存缓存或基于磁盘
我的 CSS 必须使用过渡来更改,直到现在我都使用 div:hover 来实现。 当您单击另一个 div 时需要激活过渡,而不是当您将鼠标悬停在必须移动/更改的 div 上时。 我该怎么做? 谢谢 永
在我的应用程序中,我需要一些动画,但如果它已经设置了动画,则不需要持续时间。但我的问题是它会自动添加持续时间。 在这里你可以看到 2 个函数,第二个没有持续时间但它确实有持续时间(可能从 1 秒开始)
两年前,我需要制作一个工具,通过 POST 自动将 txt/csv 文件上传到我的 Web 服务器,然后使用 cronjob 通过 PHP 对其进行解析。 这有两次在每天午夜自动发生。尽管这行得通,但
请阅读下面程序中的评论: #include void test(char c[]) { c=c+2; //why does this work ? c--; printf("%
也许是个幼稚的问题,但是...... 确认或拒绝: 自动和静态存储持续时间的对象/变量的内存的存在是在编译时确定的,程序运行时失败的可能性绝对为零,因为没有足够的内存用于自动对象。 自然地,当自动对象
有没有什么方法可以自动获得类中属性更改的通知,而不必在每个 setter 中都编写 OnPropertyChanged? (我有数百个属性,我想知道它们是否已更改)。 安东建议 dynamic pro
我们在使用 Azure DevOps 的项目中采用了 gitflow 流程。我有以下场景: 当功能分支合并到 Develop 时,我想在完成拉取请求的同时执行压缩合并策略 当 Release 分支定期
我的网站上有一个评论部分,我将 html 编码的评论保存在我的数据库中。所以我添加了这条评论- "testing" `quotes` \and backslashes\ and html 并将其保存在
是否存在“ checkin 前 TFS 自动 checkout ”这样的功能,以便在我说“ checkin ”之前我不会 checkout 任何文件,例如以防我只是临时更改文件 - 这一直发生。 换句
我有一个运行在 Linux/Apache/Tomcat 堆栈上的网站,它需要每隔几个月自动脱机以进行服务器维护,这将持续任意时间。有哪些选项可以让 Apache 建立和取消“服务器维护”页面? 我需要
我经常在工作中创建文档,在公司内部,由于我们使用的首字母缩写词和缩写词的数量,我们几乎拥有自己的语言。因此,我厌倦了在发布文档之前手动创建首字母缩写词和缩写表,并且快速的谷歌搜索发现了一个可以有效地为
我希望在用户或宏将计算模式从自动更改为手动或手动更改为自动时运行代码。是否有为此触发的事件? (属性是 Application.Calculation 在 Excel 互操作中。) 使用 Excel
这个问题在这里已经有了答案: Repeat command automatically in Linux (13 个回答) 6年前关闭。 我想创建一个脚本来获取另一个文件夹中的所有文件夹名称。并为这些
我是一名优秀的程序员,十分优秀!