Angular.js如何从PHP读取后台数据


Posted in Javascript onMarch 24, 2016

之前已经有很多方法可以通过angular进行本地数据的读取。以前的例子中,大多数情况都是将数据存放到模块的$scope变量中,或者直接利用ng-init定义初始化的数据。但是这些方法都只为了演示其他功能的效果。这次来学习一下如何将Angular和PHP相结合,从后台读取数据
首先,利用PHP,我们定义了一组后台数据,代码如下(test.php):

<?php 
header("Access-Control-Allow-Origin: *"); 
header("Content-Type: application/json; charset=UTF-8"); 
$conn = new mysqli("myServer", "myUser", "myPassword", "Northwind"); 
$result = $conn->query("SELECT CompanyName, City, Country FROM Customers"); 
$outp = ""; 
while($rs = $result->fetch_array(MYSQLI_ASSOC)) { 
  if ($outp != "") {$outp .= ",";} 
  $outp .= '{"Name":"' . $rs["CompanyName"] . '",'; 
  $outp .= '"City":"'  . $rs["City"]    . '",'; 
  $outp .= '"Country":"'. $rs["Country"]   . '"}';  
} 
$outp ='{"records":['.$outp.']}'; 
$conn->close(); 
echo($outp); 
?>

 这段代码含义比较简单,连接数据库后,从数据库中利用sql语句选择相应的数据($conn->query("SELECT CompanyName, City,Country FROM Customers"))。之后,利用循环结构,将取出的数据以键值对的形式保存在$outp变量中。
接下来,在js中操作如下:

<div ng-app="myApp" ng-controller="customersCtrl">  
<table> 
 <tr ng-repeat="x in names"> 
  <td>{{ x.Name }}</td> 
  <td>{{ x.Country }}</td> 
 </tr> 
</table> 
</div> 
<script> 
var app = angular.module('myApp', []); 
app.controller('customersCtrl', function($scope, $http) { 
  $http.get("test.php") 
  .success(function (response) {$scope.names = response.records;}); 
}); 
</script>

 这里仍然应用了$http服务进行数据的读取,传入数据文件对应的url路径,成功后返回数据,并绑定到$scope.names变量上。

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
js使浏览器窗口最大化实现代码(适用于IE)
Aug 07 Javascript
浅谈javascript中自定义模版
Jan 29 Javascript
jQuery on()方法使用技巧详解
Apr 16 Javascript
JQuery实现鼠标移动图片显示描述层的方法
Jun 25 Javascript
JS建造者模式基本用法实例分析
Jun 30 Javascript
js变形金刚文字特效代码分享
Aug 20 Javascript
javascript模拟C#格式化字符串
Aug 26 Javascript
JavaScript字符串常用的方法
Mar 10 Javascript
原生JS轮播图插件
Feb 09 Javascript
JavaScript原生实现观察者模式的示例
Dec 15 Javascript
jQuery实现简单弹幕效果
Nov 28 jQuery
vue路由实现登录拦截
Mar 24 Vue.js
JavaScript驾驭网页-获取网页元素
Mar 24 #Javascript
JavaScript驾驭网页-CSS与DOM
Mar 24 #Javascript
JavaScript驾驭网页-DOM
Mar 24 #Javascript
常用的JQuery函数及功能小结
Mar 24 #Javascript
JS中setTimeout的巧妙用法前端函数节流
Mar 24 #Javascript
Zero Clipboard实现浏览器复制到剪贴板的方法(多个复制按钮)
Mar 24 #Javascript
不能不知道的10个angularjs英文学习网站
Mar 23 #Javascript
You might like
php下使用无限生命期Session的方法
2007/03/16 PHP
使用php从身份证号中获取一系列线索(星座、生肖、生日等)
2016/05/11 PHP
thinkPHP5.0框架应用请求生命周期分析
2017/03/25 PHP
laravel框架中视图的基本使用方法分析
2019/11/23 PHP
通过JAVASCRIPT读取ASP设定的COOKIE
2007/02/15 Javascript
增强的 JavaScript 的 trim 函数的代码
2007/08/13 Javascript
javascript RadioButtonList获取选中值
2009/04/09 Javascript
jQuery学习总结之元素的相对定位和选择器(持续更新)
2011/04/26 Javascript
jQuery学习笔记 操作jQuery对象 文档处理
2012/09/19 Javascript
js实现弹出窗口、页面变成灰色并不可操作的例子分享
2014/05/10 Javascript
JS判断移动端访问设备并加载对应CSS样式
2014/06/13 Javascript
js实现下拉框选择要显示图片的方法
2015/02/16 Javascript
AngularJS 入门教程之HTML DOM实例详解
2016/07/28 Javascript
js插件Jcrop自定义截取图片功能
2016/10/14 Javascript
Bootstrap简单表单显示学习笔记
2016/11/15 Javascript
Django1.7+JQuery+Ajax验证用户注册集成小例子
2017/04/08 jQuery
详解如何用模块化的方式写vuejs
2017/12/16 Javascript
一步步教你利用webpack如何搭一个vue脚手架(超详细讲解和注释)
2018/01/08 Javascript
详解vue-cli项目中怎么使用mock数据
2018/05/29 Javascript
如何使用 vue + d3 画一棵树
2018/12/03 Javascript
JavaScript实现PC端横向轮播图
2020/02/07 Javascript
vscode 插件开发 + vue的操作方法
2020/06/05 Javascript
10个Python小技巧你值得拥有
2018/09/29 Python
在Python 中实现图片加框和加字的方法
2019/01/26 Python
Python简易版图书管理系统
2019/08/12 Python
python树的同构学习笔记
2019/09/14 Python
python圣诞树编写实例详解
2020/02/13 Python
Django框架静态文件处理、中间件、上传文件操作实例详解
2020/02/29 Python
基于HTML5超酷摄像头(HTML5 webcam)拍照功能实现代码
2012/12/13 HTML / CSS
amazeui页面校验功能的实现代码
2020/08/24 HTML / CSS
加拿大最大的书店:Indigo
2017/01/01 全球购物
客户服务经理岗位职责
2014/01/29 职场文书
生物科学专业职业规划书范文
2014/02/11 职场文书
大学生会计职业生涯规划范文
2014/02/28 职场文书
酒店管理专业自荐信
2014/05/23 职场文书
小学生成绩单评语
2014/12/31 职场文书