Azure移动服务:javascript中的基本读取功能

时间:2013-10-15 23:31:39

标签: javascript azure-mobile-services

我正在学习javascript和windowsazure移动服务。作为一门学习课,我创建了一个“用户”表并插入了一个测试用户。我实际上正在使用icenium为ipad和andoid平板电脑编写一个演示应用程序,但我似乎无法弄清楚即使是最基本的请求。所以我在这里设置了一个jsfiddle:http://jsfiddle.net/MNubd/5/

这是一个简单的输入框:

<input id="uFullName" type="text" />

和一些javascript代码。我正在尝试从“用户”表中检索“名称”列,并将其显示在输入框中:

alert('running');
var client = new WindowsAzure.MobileServiceClient('https://mtdemo.azure-mobile.net/', 'MtxOqGpaBzuPRtnkIifqCKjVDocRPY47');
usersTable = client.getTable('users');
usersTable.where({ userID: 'impretty@blockedheaded.com' }).read({
    success: function (results) {
        $('#uFullName').val(results);
    },
    error: function (err) {
        $('#uFullName').val('there was and err');
    }
});

感谢您的帮助!

编辑:我不知道成功函数只能在服务器脚本上使用。谢谢。以下是最终为我工作的代码:

function signInButton(e) {
    var un = $('#username');
    uName = un.val();
    var client = new WindowsAzure.MobileServiceClient('https://mtdemo.azure-mobile.net/', 'MtxOqGpaBzuPRtnkIifqCKjVDocRPY47');    
    //alert('lookup: ' + uName);
    usersTable = client.getTable('users');    
    usersTable.where({ userID: uName })
    .read()
    .done(
        function (results) {            
            try {
                xUserName = results[0].name; //using this to trigger an exception if the login credentials don't match.
                xUserID = results[0].id; // save this for querying and adding records for this user only.
                //alert('found');
                app.application.navigate('#view-menu');                        
            }
            catch(err) {
                 //alert('not found');
                 document.getElementById('errorText').textContent = "Check Email and Password!";                 
            }            
        } 
    );//end of the done

1 个答案:

答案 0 :(得分:0)

带有successerror回调对象的options对象仅用于服务器端脚本。对于客户端,编程模型基于promise,您应该使用done()(或then())延续来获得结果:

var client = new WindowsAzure.MobileServiceClient('https://mtdemo.azure-mobile.net/', 'YOUR-KEY');
var usersTable = client.getTable('users');
usersTable.where({ userID: 'impretty@blockheaded.com' }).read().done(function (result) {
    $("#uFullName").val(result.name);
}, function (err) {
    $("#uFullName").val('There was an error: ' + JSON.stringify(err));
});