随着Web技术的快速发展,越来越多的应用需要实时的数据更新,Angular作为目前比较流行的前端框架之一,它的数据绑定和指令等功能非常强大,可以实现实时更新数据。在实际应用中,我们常常需要将前端数据与数据库中的数据做双向同步,本文旨在介绍的方法。
一、前端数据改变的监听
为了实现前后端数据的同步,在Angular中需要监测前端数据的变化。Angular通过$watch服务来监听Scope中数据的变化,当Scope中数据发生变化时,Angular会自动更新视图。$watch的语法如下:
“`javascript
$watch(watchExpression, listener, [objectEquality])
“`
其中,watchExpression表示需要监控的表达式,它可以是字符串或者函数,listener是数据变化时需要执行的函数,objectEquality是可选参数,用来比较对象类型的值是否相等,默认是false。
下面是一个简单的例子,当输入框中的值改变时,会动态更新页面中的数据:
“`html
Hello, {{ name }}
var app = angular.module(‘myApp’, []);
app.controller(‘myCtrl’, function($scope) {
$scope.name = ‘Angular’;
$scope.$watch(‘name’, function(newVal, oldVal) {
console.log(‘value changed from ‘+ oldVal + ‘ to ‘+ newVal);
});
});
“`
上述代码在控制台输出 value changed from Angular to {{ new value }}。
二、前端数据的提交
在前端数据改变时,需要将改变后的数据提交到后台,如果使用jQuery可以通过AJAX异步请求来实现,而Angular提供了更为便捷的服务——$http服务。
$http服务是Angular中的一个核心服务,可用于发送HTTP请求和处理返回数据。与jQuery中的$.ajax()类似,$http方法可以发送异步请求并处理成功或错误的响应,该服务具有以下语法:
“`javascript
$http({
method: ‘GET|POST|PUT|DELETE|ONP’,
url: ‘your url’,
data: your data,
params: your param,
headers: your header
}).then(successCallback, errorCallback);
“`
其中,method是HTTP请求方法,url是请求地址,data是需要提交的数据,params是请求参数,headers则是HTTP头信息,successCallback和errorCallback分别是请求成功和请求失败后需要执行的回调函数。
下面是一个简单的例子,当点击Save按钮后,将数据提交到后台:
“`html
var app = angular.module(‘myApp’, []);
app.controller(‘myCtrl’, function($scope, $http) {
$scope.name = ‘Angular’;
$scope.submit = function() {
$http({
method: ‘POST’,
url: ‘/update’,
data: { name: $scope.name }
}).then(function(response) {
console.log(‘submit success’);
}, function(response) {
console.log(‘submit error’);
});
};
});
“`
三、后端数据的更新
前端数据提交后,后台需要接收数据并更新到数据库中,此时需要使用后端语言(例如PHP、Java)编写API接口来实现。这里以PHP为例,假设我们已经有一个API用于更新数据:
“`php
// 执行更新操作,更新$data到数据库中
function update($data) {
// 这里省略数据库操作的代码
// …
return true;
}
$data = json_decode(file_get_contents(‘php://input’), true);
if (update($data)) {
echo json_encode(array(‘code’ => 0, ‘msg’ => ‘success’)); // 执行成功,返回code=0
} else {
echo json_encode(array(‘code’ => -1, ‘msg’ => ‘error’)); // 执行失败,返回code=-1
}
?>
“`
前端需要根据后台返回的结果来判断更新是否成功,在此基础上调整$http服务的回调函数:
“`html
var app = angular.module(‘myApp’, []);
app.controller(‘myCtrl’, function($scope, $http) {
$scope.name = ‘Angular’;
$scope.submitting = false;
$scope.submit = function() {
$scope.submitting = true;
$http({
method: ‘POST’,
url: ‘/update’,
data: { name: $scope.name }
}).then(function(response) {
$scope.submitting = false;
if (response.data.code === 0) {
console.log(‘submit success’);
} else {
console.log(‘submit error’);
}
}, function(response) {
$scope.submitting = false;
console.log(‘submit fled’);
});
};
});
“`
上述代码中,我们添加了一个submitting变量来控制表单提交状态,在$http的回调函数中判断返回结果的code值,根据执行结果进行处理。
四、实现实时更新
使用上述方法可以实现前后端数据的同步,但是如果需要实现实时更新,则需要加入长轮询、WebSocket、Server-Sent Events(HTML5的一项新特性)等技术。这里以WebSocket为例进行说明。
WebSocket是一种与HTTP协议不同的协议,它可以直接在客户端和服务器之间创建持久性的连接通道,实现实时双向数据传输。在Angular中,可以使用ngWebSocket模块来实现WebSocket的封装,具有以下语法:
“`javascript
var socket = new WebSocket(‘ws://localhost:8080’);
socket.onopen = function() {
console.log(‘WebSocket connected’);
};
socket.onmessage = function(event) {
console.log(‘receive message from server: ‘ + event.data);
};
socket.onclose = function() {
console.log(‘WebSocket closed’);
};
socket.onerror = function(error) {
console.log(‘WebSocket error: ‘ + error);
};
“`
上述代码中,我们创建了一个WebSocket连接,并通过回调函数来监听WebSocket的状态和接收数据。需要注意的是,WebSocket连接的地址和具体协议格式需要根据服务端实现进行调整。
如果要实现前端数据的实时更新,通常需要在服务器端接收到更新数据时主动向前端发送推送数据。下面是一个简单的PHP实现:
“`php
header(‘Content-Type: text/event-stream’);
header(‘Cache-Control: no-cache’);
// 每1s向客户端发送当前时间
while (true) {
$time = date(‘r’);
echo “data: {$time}nn”;
flush();
sleep(1);
}
?>
“`
服务器每隔1s向客户端发送一条数据,前端在收到数据后通过$apply方法来更新视图:
“`html