本篇主要汇总一下使用Framework7 + Angular 开发中遇到的一些难点及我的解决方法,以后再遇到会在这里继续更新。

一、页面表格按需加载

情况描述:默认加载10条,在用户上拉页面是再进行下一页的内容加载。

解决方法:利用Framework7 的无限滚动。

1、页面:

<tbody id="orderContent">
<tr ng-repeat="order in orderInfoList">
<td><span ng-if="order.orderNo == null">--</span><span ng-if="order.orderNo != null">{{order.orderNo}}</span></td>
<td><span ng-if="order.orderType == null">--</span><span ng-if="order.orderType != null">{{order.orderType}}</span></td>
<td><span ng-if="order.completeStatus == null">--</span><span ng-if="order.completeStatus != null">{{order.completeStatus}}</span></td>
<td class=" ">
<button class="btn btn-primary btn-xs" ng-click="selectOrderInfoDetailModel($index);">详情</button>
<button class="btn btn-warning btn-xs" ng-click="deleteOrderInfoDetailModel($index);">删除</button>
</td>
</tr>
</tbody>

将后面加载的内容插入到 id="orderContent" 的 tbody 中。

2、js(只显示关键代码,其他用省略号代替):

            ......
$scope.queryParam = {}; ......
// 初始化分页参数
$scope.pgPageInfo = {
pageNum: 1,
pageSize: 20
};
// 初始化 无限加载 参数
var $$ = Dom7;
var loading = false; $$('.infinite-scroll').on('infinite', function () {
moreOrderInfo();
}); function moreOrderInfo() {
var lastLoadedIndex = $$('#orderContent tr').length; ...... // 全部内容加载完后,显示底线,return
if (lastLoadedIndex >= $scope.pgPageInfo.total) {
$('#orderNomore').show();
return;
} var param = $scope.queryParam; // 查询参数
param.pageInfo = {
pageNum: $scope.pgPageInfo.pageNum + 1,
pageSize: 20
}; PiecesListFactory.queryOrderInfoRequest(param).then(function (data) {
loading = false; app.myApp.hideIndicator(); ModalFactory.hideLoading();
if (null == data) {
app.myApp.detachInfiniteScroll($$('.infinite-scroll'));
$$('.infinite-scroll-preloader').remove();
} else {
$scope.pgPageInfo = data.pageInfo; var orderHtml = "";
for (var i = 0; i < data.result.length; i++) {
// 循环data.result,得到拼接的orderHtml
} $('#orderContent').append(orderHtml); // 将加载的内容插入到页面 lastLoadedIndex = $$('#orderContent tr').length; } }, function (data) {
app.myApp.hideIndicator();
ModalFactory.alert("数据加载失败!");
});
}

3、还有一个地方,就是在angular初始化的时候,要对列表内容块加上Framework7 的滚动监听

           var init = function () {

                app.myApp.attachInfiniteScroll($$(".infinite-scroll"));

            };
init();

二、页面中 angularJS 动态加载的内容,ng-click 无效

情况描述:完成了上面的列表内容动态加载,又遇到了一个问题,如果加载的内容不触发事件,就完事了,可是我这里,列表有个操作(详情,删除),所以之后发现动态加载的内容中 angularJS 的 ng-click 无效。。。

解决方法:用 $compile服务 编译一下动态加载的内容。

将上面的    $('#orderContent').append(orderHtml);   中的动态内容 orderHtml 处理一下::

var orderLink = $compile(orderHtml);
$('#orderContent').append(orderLink($scope));

Framework7 + Angular 开发问题解决汇总的更多相关文章

  1. Kinect开发资源汇总

    Kinect开发资源汇总   转自: http://www.sigvc.org/bbs/forum.php?mod=viewthread&tid=254&highlight=kinec ...

  2. cordova开发问题汇总

    cordova开发问题汇总 1. 导入工程的"The import android cannot be resolved"错误解决方法 2. MainActivity] Unabl ...

  3. Win10 FaceAPI小demo开发问题汇总

    Win10 FaceAPI小demo开发问题汇总 最近使用微软牛津计划做一个小demo,使用FaceAPI做一个小应用,实现刷脸的功能.开发的过程中用到几个问题,具体如下: Stream 与IRand ...

  4. android开发问题汇总

    android开发问题汇总 一. 无法创建新android项目 在eclipse创建新项目时出现: this template depends on the android support libra ...

  5. Visual Studio Code作为Angular开发工具常用插件安装、json-server安装与使用、angular/cli安装失败问题

    前提准备: 搭建好Angular开发环境 1 安装Visual Studio Code 教程简单,不会的去问度娘 2 安装Chrome浏览器 教程简单,不会的趣闻度娘 3 Visual Studio ...

  6. Angular开发实践(一):环境准备及框架搭建

    引言 在工作中引入Angular框架将近一年了,在这一年中不断的踩坑和填坑,当然也学习和积累了很多的知识,包括MVVM框架.前后端分离.前端工程化.SPA优化等等.因此想通过Angular开发实践这系 ...

  7. Android进阶(二十)AndroidAPP开发问题汇总(四)

    · Android进阶(二十)AndroidAPP开发问题汇总(四) android:layout_width和android:width的区别 基中的android:layout_width和and ...

  8. Android进阶(十九)AndroidAPP开发问题汇总(三)

    Android进阶(十九)AndroidAPP开发问题汇总(三) Java解析XML的几种方式: http://inotgaoshou.iteye.com/blog/1012188 从线程返回数据的两 ...

  9. Android进阶(十八)AndroidAPP开发问题汇总(二)

    Android进阶(十八)AndroidAPP开发问题汇总(二) 端口被占用解决措施: Android使用SimpleAdapter更新ListView里面的Drawable元素: http://ww ...

随机推荐

  1. Android笔记(三十) Android中线程之间的通信(二)Handler消息传递机制

    什么是Handler 之前说过了,Android不允许主线程(MainThread)外的线程(WorkerThread)去修改UI组件,但是又不能把所有的更新UI的操作都放在主线程中去(会造成ANR) ...

  2. Ajax 的简介与使用

    一.什么是Ajax Ajax 的全称是 Asynchronous JavaScript and XML(即异步的 JavaScript 和 XML),是一种在无需重新加载整个网页的情况下,能够更新部分 ...

  3. JS多线程之Web Worker

    什么是Web Worker web worker 是运行在后台的 JavaScript,不会影响页面的性能. 当在 HTML 页面中执行脚本时,页面的状态是不可响应的,直到脚本已完成. web wor ...

  4. MyCat(1.1)Mycat基本介绍

    [1]学习目的 (1)掌握在数据库负载增大时的处理方法 (2)理解mycat的基础概念 (3)掌握mycat基础配置和监控方法 [2]Mycat的前世今生 官网:http://mycat.io/ 下载 ...

  5. Mac---使用tree生成目录结构

    作为测试或者程序员,平时都有需求来生成目录树,进行项目层级的讲解等.如下是样式图: 实现方式,即操作步骤: Mac下使用 brew install tree 进行安装,安装后,在terminal中输入 ...

  6. 删除TOMCAT服务器上的文件

    deleteFile(文件名称,路径名称); public boolean deleteFile(String filename,String filepath){  String path =Ser ...

  7. IAR平台移植TI OSAL到STC8A8K64S4A12单片机中

    玩过TI 的ZigBee或者BLE的人,都会接触到OSAL.OSAL是什么?OSAL英文全称:operating system abstraction layer(操作系统抽象层).基于OSAL的调度 ...

  8. Mac+Appium+Python+Pycharm环境搭建

    为什么优先选择Mac做自动化测试? 1.既可以做iOS端的测试也可以进行Android端测试 2.Mac运行效率相对于Win要高很多,可以真正发挥appium的功能 以下是在Mac上完整搭建过程 一. ...

  9. Educational Codeforces Round 75 (Rated for Div. 2) B. Binary Palindromes

    链接: https://codeforces.com/contest/1251/problem/B 题意: A palindrome is a string t which reads the sam ...

  10. nginx配置url伪静态

    rewrite 规则 定向路径 重写类型; 举例: rewrite  (.*)/web/(.*)-(.*)-(.*).html$  $1/web/index.php?r=$2/$3/$4  last; ...