- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我一直在研究 Angular.js 教程,现在我想扩展它。这是一个简单的 CRUD 应用程序,具有模板列表:list.html(仅在数据库中记录标题和内容)、创建表单:new.html 和编辑表单:edit.html。
刚才 list.html 从我的 REST 应用加载模板数组并将它们显示在表格中。有一个搜索表单和一些排序功能。
New.html 有一个用于创建新模板的表单。
这两个 .html 文件是通过不同的路径加载的。 #/
和#/new
我现在想要做的是拥有一个文件index.html,它将list.html 加载到一个div 中,然后将new.html 加载到另一个div 中。这个想法是记录列表将始终显示在左侧,然后其他部分将加载到右侧区域。因此,单击列表中的模板将在列表旁边的区域中打开它,但列表保持不变。然后,如果我单击新模板按钮,新模板表单将重新出现在内容区域中,但列表将保持不变。
这是我的代码:
应用程序.js
var MailStash = angular.module("MailStash", ["ngResource"]).
config(function($routeProvider){
$routeProvider.
when('/', {controller: ListCtrl, templateUrl: '/js/partials/list.html'}).
when('/new', {controller: CreateCtrl, templateUrl: '/js/partials/new.html'}).
when('/edit/:editId', {controller: EditCtrl, templateUrl: '/js/partials/edit.html'})
});
MailStash.factory('Template', function($resource){
return $resource('/api/v1/template/:id', {id: '@id'}, { update: { method: 'PUT' } });
});
var EditCtrl = function($scope, $location, $routeParams, Template) {
$scope.action = "Update";
var id = $routeParams.editId;
$scope.template = Template.get({id: id});
$scope.save = function () {
Template.update({id: id}, $scope.template, function () {
$location.path('/');
});
};
}
var CreateCtrl = function($scope, $location, Template) {
$scope.save = function() {
Template.save($scope.template, function(){
$location.path('/');
});
}
}
var ListCtrl = function($scope, $location, Template) {
$scope.search = function() {
Template.query({
q: $scope.query,
sort_order: $scope.sort_order,
is_desc: $scope.is_desc,
offset: $scope.offset,
limit: $scope.limit
},
function(data){
$scope.more = data.length === 20;
$scope.templates = $scope.templates.concat(data);
});
}
$scope.sort = function(col) {
if($scope.sort_order === col) {
$scope.is_desc = !$scope.is_desc;
} else {
$scope.sort_order = col;
$scope.is_desc = false;
}
$scope.reset();
};
$scope.showMore = function(){
$scope.offset += $scope.limit;
$scope.search();
};
$scope.hasMore = function(){
return $scope.more;
}
$scope.reset = function() {
$scope.limit = 10;
$scope.offset = 0;
$scope.templates = [];
$scope.more = true;
$scope.search();
}
$scope.delete = function() {
var id = this.template.id;
Template.delete({id: id}, function(){
$('#template_'+id).fadeOut();
});
}
$scope.sort_order = "title";
$scope.is_desc = false;
$scope.reset();
};
列表.html:
<form class="form-search">
<div class="input-append">
<input type="text" ng-model="query" class="input-medium search-query" placeholder="Search">
<button ng-click="reset()" type="submit" class="btn"><i class="icon-search"></i></button>
</div>
<button ng-click="query=''; reset()" ng-disabled="!query" type="submit" class="btn">Reset</button>
</form>
<p class="sort">
Sort:
<a ng-click="sort('title')">Title</a>
<span ng-show="sort_order=='title' && is_desc==true"><i class="icon icon-arrow-down"> </i></span>
<span ng-show="sort_order=='title' && is_desc==false"><i class="icon icon-arrow-up"> </i></span>
|
<a ng-click="sort('created_at')">Date Created</a>
<span ng-show="sort_order=='created_at' && is_desc==true"><i class="icon icon-arrow-down"> </i></span>
<span ng-show="sort_order=='created_at' && is_desc==false"><i class="icon icon-arrow-up"> </i></span>
</p>
<table class="table">
<tbody>
<tr ng-repeat="template in templates" id="template_{{template.id}}">
<td>{{template.title}}</td>
</tr>
</tbody>
</table>
<a ng-show="hasMore()" ng-click="showMore()">Show more</a>
<hr>
<a href="/#/new" class="btn"><i class="icon icon-plus"> </i> New Template</a>
New.html
<h2>New Template</h2>
<form name="new_template">
<div class="control-group" ng-class="{error: form.title.$invalid}">
<div class="controls">
<input type="text" class="span6" ng-model="template.title" name="title" id="title" value="" placeholder="Template name" />
</div>
</div>
<div class="control-group" ng-class="{errors: form.content.$invalid}">
<div class="controls">
<textarea name="content" ng-model="template.content" id="content" class="template-content span12" rows="15"></textarea>
</div>
</div>
<div class="form-actions">
<button ng-click="save()" class="btn btn-primary save-template">Save Template</button>
</div>
</form>
我的布局文件:
<!DOCTYPE html>
<html ng-app="MailStash" xmlns="http://www.w3.org/1999/xhtml" xmlns:fb="http://ogp.me/ns/fb#">
<head>
<title>MailStash</title>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="author" content="Billy Jones - http://theninthnode.com">
{{ Html::style('css/bootstrap.cerulean.min.css') }}
@yield('css')
{{ Html::style('css/style.css') }}
</head>
<body class="preview" data-spy="scroll" data-target=".subnav" data-offset="80">
<div class="container-fluid">
@include('common.header-fluid')
</div>
<div class="container-fluid main">
<div ng-view></div>
@include('common.footer')
</div>
{{ HTML::script('js/jquery.min.js') }}
{{ HTML::script('js/bootstrap.min.js') }}
{{ HTML::script('js/angular.min.js') }}
{{ HTML::script('js/angular-resource.min.js') }}
{{ HTML::script('js/jquery.dataTables.min.js') }}
@yield('scripts')
{{ HTML::script('js/app.js') }}
{{ HTML::script('js/main.js') }}
</body>
</html>
我尝试使用:
<div class="row-fluid">
<div class="span3">
<div ng-include="'/js/partials/list.html'"></div>
</div>
<div class="span9">
<div ng-include="'/js/partials/new.html'"></div>
</div>
</div>
但是我失去了这些部分的功能。即搜索表单停止工作,新模板表单停止工作。
最佳答案
我想你的意思是你正在替换 <div ng-view></div>
最后一个 block 有 2 ng-include
.
如果是这样,您可能不需要 controller
在路由配置中定义,需要添加 ng-controller
html 的属性
关于javascript - AngularJS 中的多个独立部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16000568/
我如何使用 CQLINQ 获取当前方法的输入参数集合?有像“参数”或“参数”这样的集合,只有“NbParamenter”不适合我的目的。 最佳答案 事实上,CQLinq 还没有这个功能。但是,在许多情
我想知道是否有人知道我的 makefile 中独立的 @ 符号和“dir”命令在这里(第二行和第三行)的作用: $(BUILD)/%.o: %.cpp @mkdir -p $(dir $@)
我想知道是否有人知道我的 makefile 中独立的 @ 符号和“dir”命令在这里(第二行和第三行)的作用: $(BUILD)/%.o: %.cpp @mkdir -p $(dir $@)
我的机器上有带有 4 个 cpu 的 Ubuntu 14.04(nproc 恢复了 4 个)。我安装并执行 Spark Standalone 后(本地),我可以自己定义不同数量的奴隶。例如我想要有4个
我看到所有这些 iPhone 应用程序都带有内置的独立 webDav 服务器。是否有可以集成到现有应用程序中的独立(如在其自己的 IIS 中)C# webDAV 项目。 最佳答案 至少有两个用于 .N
我如何在独立的 Django 应用程序上进行迁移(即不属于任何项目的应用程序)。 例如在以下之后:https://docs.djangoproject.com/en/1.8/intro/reusabl
我目前正在使用 tortoiseSVN 对本地编程文件进行版本控制。我不运行 SVN 服务器,因为可以直接使用 tortoiseSVN(例如 http://invalidlogic.com/2006/
我有一些 Bootstrap 代码,当用户查看它时,它可以很好地为进度条部分设置动画。 然而它动画 全部 页面中的进度条而不是动画仅限 该查看部分中的进度条。结果,当用户转到进度条的另一部分时,这些已
我认为我们在 iOS 13.2/13.3 中发现了关于在独立模式下运行的 PWA 的回归。 由于在 iOS PWA 上无法访问 getUserMedia() 我们依赖 capture HTML5 输入
我有一个每周从系统运行一次的报告,并将数据导出到 Excel 文档中。我已经设置了将数据导出到 Excel 的工具,以便在格式化方面做得很好,但是一旦数据进入 Excel,我还需要做更多的事情。 是否
//值数组的格式为 { "var1", "val1", "var2", "val2",.. } public static String replaceMethod(String template,
当我在 eclipse 中运行我的项目时,它工作正常,当我将它导出为独立 jar 时,它会滞后。我使用相同的 vmargs,在 Eclipse 中尝试了 3 种不同的导出设置,似乎没有任何帮助 最佳答
我了解到 Java EE 中我非常喜欢的注释基础配置(@Resource)功能。然后我注意到注释实际上是 Java SE 的一部分。 所以我想知道是否可以将它与 Java SE 一起使用。我当然可以在
我无法理解为什么这种关系没有被持久化,并且程序不会正常退出,但在 Eclipse 中继续运行。 下面是我的代码,排除了包名: 主要: import java.io.BufferedInputStrea
我有一个在 Linux + Java 6 上运行的独立 Java 应用程序,它似乎被卡住了(没有生成日志)我如何在不使用任何其他工具(例如 jstack)的情况下获取此线程转储 尝试了以下命令,但它们
我正在非节点环境中构建应用程序,但我想利用 Babel 的 ES6 转译,以便我可以编写更好的代码并且仍然支持 IE11。 所以我继续包含在这里找到的独立文件: https://github.com/
扩展我对 MySQL 的理解。 1) 是否需要 64 位帮助?我是安装还是单独使用? 2) 如果我打算在 MySQL Community Service 中使用 64 位,它会影响仅提供 32 位的
我有一个独立的 Java 应用程序,我必须为其集成一个规则引擎。我应该使用属性文件或 XML 文件定义规则。我需要规则引擎来读取属性或 XML 文件中定义的这些规则,并相应地在应用程序中实现代码。 任
我是wiremock新手,我正在尝试使用它来记录我负责集成测试的java应用程序的请求和响应。 我知道我的命令将类似于: java -jar wiremock-1.57-standalone.jar
我到处寻找我的问题的解决方案,但我的问题有点具体...我需要有关如何创建独立 radioGroup 列表的建议,例如图示: o item1 • item1' • item2 或 item2' o it
我是一名优秀的程序员,十分优秀!