- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道如何根据我的输入将数据添加到模式。这是我的代码:
主文件
var Bintime = new Marionette.Application();
Bintime.on("before:start", function(){
var RegionContainer = Marionette.LayoutView.extend({
el: "#app",
regions: {
contacts: "#contacts",
name: "#name",
messages: "#messages",
input: "#input"
}
});
Bintime.regions = new RegionContainer();
});
Bintime.on("start", function(){
Bintime.Contacts.List.Controller.listContacts();
});
<小时/>
型号
Bintime.module("Contacts", function(Contacts, Bintime, Backbone, Marionette, $, _){
Contacts.Contacts = Backbone.Model.extend({});
Contacts.ContactsCollection = Backbone.Collection.extend({
model: Contacts.Contacts,
comparator: "firstName"
});
var contacts;
var initializeContacts = function(){
contacts = new Contacts.ContactsCollection([
{
id: 1,
firstName: "Alice",
lastName: "Arten",
messages: [
{
from: "1",
message: "Hello"
},
{
from: "1",
message: "How r u?"
},
{
to: "1",
message: "Hey!"
},
{
to: "1",
message: "Great!"
}
]
},
{
id: 2,
firstName: "Bob",
lastName: "Brigham"
},
{
id: 3,
firstName: "Charlie",
lastName: "Campbell"
}
]);
};
var API = {
getContactContact: function(){
if(contacts === undefined){
initializeContacts();
}
return contacts;
}
};
Bintime.reqres.setHandler("contacts:contacts", function(){
return API.getContactContact();
});
});
<小时/>
主 Controller
Bintime.module("Contacts.List", function(List, Bintime, Backbone, Marionette, $, _) {
List.Controller = {
listContacts: function() {
var contacts = Bintime.request("contacts:contacts");
var contactsView = new List.Contacts({
collection: contacts
});
contactsView.on("childview:contact:contacts", function(childView, model) {
Bintime.Contact.Name.Controller.nameContact(model);
});
contactsView.on("childview:chat:contacts", function(childView, model) {
Bintime.Contacts.Messages.Controller.chatMessages(model);
});
contactsView.on("childview:message:contacts", function(childView, model) {
Bintime.Message.Input.Controller.messageField(model);
});
Bintime.regions.contacts.show(contactsView);
}
}
});
<小时/>
模块 Controller ,从输入添加消息
Bintime.module("Message.Input", function(Input, Bintime, Backbone, Marionette, $, _) {
Input.Controller = {
messageField: function(model){
var contacts = new Input.Contacts({
model: model
});
Bintime.regions.input.show(contacts);
}
}
});
<小时/>
查看模块,从输入添加消息
Bintime.module("Message.Input", function(Input, Bintime, Backbone, Marionette, $, _) {
Input.Contacts = Marionette.ItemView.extend ({
template: "#new",
events: {
"change input#message-input": "sendInput"
},
sendInput: function(e){
e.preventDefault();
var message = this.$("input#message-input").val();
console.log(message);
}
});
$('#new').append(v.el);
});
<小时/>
index.html
<div id="app" class="full-width full-height">
<div class="full-width full-height">
<div class="large-3 column contacts nopadding full-height">
<div id="contacts">
</div>
</div>
<div class="large-9 column full-height nopadding">
<div id="name" class="user full-width">
<div>
</div>
</div>
<div id="messages">
</div>
<div id="input">
</div>
</div>
</div>
</div>
<script type="text/template" id="contacts-list">
<div class="contact">
<div class="center text-center">
<a href="#"><span class="text-center"><%= firstName%> <%= lastName%></span></a>
</div>
</div>
</script>
<script type="text/template" id="user">
<h5 class="text-center"><%= firstName%> <%= lastName%></h5>
</script>
<script type="text/template" id="message">
<% _.each(messages, function (item) { %>
<div class="message">
<div>
<% if (item.from) { %>
<div class="in">
<%= item.message %>
</div>
<% } else if (item.to) { %>
<div class="out">
<%= item.message %>
</div>
<% } %>
</div>
</div>
<% }); %>
</script>
<script type="text/template" id="new">
<div class="enter full-width">
<input id="message-input" type="text" placeholder="Enter your message..">
</div>
<a href="#" id="send" class="button">
<span>Send</span>
</a>
</script>
如您所见,我已经从输入字段获取了数据:
sendInput: function(e){
e.preventDefault();
var message = this.$("input#message-input").val();
console.log(message);
}
但我无法将数据添加到模型中。我尝试使用 .set()
执行此操作,但它覆盖了我的所有 messages
数组。类似的东西,但不完全相同:
sendInput: function(e){
e.preventDefault();
var field = $(e.currentTarget);
var message = this.$("input#message-input").val();
var data = {};
data[field.attr("messages")] = message;
this.model.set(data);
}
将“111”字符串添加到模型的结果,如上一个示例:
所以,基本上我需要向我的模型添加新消息。像这样:
id: 1,
firstName: "Alice",
lastName: "Arten",
messages: [
{
from: "1",
message: "Hello"
},
{
from: "1",
message: "How r u?"
},
{
to: "1",
message: "Hey!"
},
{
to: "1",
message: "Great!"
},
{
to: "1",
message: "HERE SHOULD BE NEW MESSAGE"
}
]
最佳答案
假设您可以通过 this.model
访问模型,其属性哈希如下所示:
{
id: 1,
firstName: "Alice",
lastName: "Arten",
messages: [{
from: "1",
message: "Hello"
},
{
from: "1",
message: "How r u?"
},
{
to: "1",
message: "Hey!"
},
{
to: "1",
message: "Great!"
}]
}
如问题所示,您可以向其中添加一条新消息,如下所示:
this.model.get("messages").push({
to: "1", // fill this as per your logic
message: message
});
这是可行的,因为对象在 JavaScript 中是通过引用传递的,而数组是特殊的对象。
关于javascript - 从输入将数据添加到模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33990490/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!