Foxtable(狐表)用户栏目专家坐堂 → 网页反馈计算结果问题


  共有4309人关注过本帖树形打印复制链接

主题:网页反馈计算结果问题

帅哥哟,离线,有人找我吗?
ycs5801
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1064 积分:7581 威望:0 精华:0 注册:2009/6/24 9:44:00
网页反馈计算结果问题  发帖心情 Post By:2021/12/22 0:20:00 [只看该作者]

在"d:\web"目录下,建立一个子目录lib,在这个目录建立一个文本文件,文件名为"ajaxform.js",文件内容为:

function myfunction(){
    var result = submitAjaxForm('form1','',false);
    if (result =='OK') {show('dlg1')}
    else {showDialog('dlg2','错误',result)}
}

Select Case e.Path
    Case "addnew.htm"
        Dim wb As New weui
        wb.AddForm("","form1","handle.htm") '指定接收表单数据的的页面为handle.htm
        With wb.AddInputGroup("form1","ipg1","新增订单")
          
            .AddInput("数量","数量","number")
            .AddInput("单价","单价","number").Step = 0.1
        End With
        With wb.AddButtonGroup("form1","btg1",True)
            .Add("btn1", "确定", "button").Attribute= ""
        End With
        With wb.AddDialog("","dlg1", "提示","增加数据完成,是否生成价格?") 
            .AddButton("btnYes","是").Attribute = "onclick=???" 想点击是则自动计算出价格处的数值。
            .AddButton("btnNo","否","http://www.foxtable.com").Kind = 1
        End With
        With wb.AddDialog("","dlg2", "错误","") '增加订单失败提示框
            .AddButton("btnOK","确定")
        End With
        wb.AppendHTML("<script src='./lib/ajaxform.js'></script>") '引入脚本文件
        e.WriteString(wb.Build)

想在此处显示价格数值。这个价格标题和方框要一直在页面上。

    Case "handle.htm"
        Dim nms() As String = {"数量","单价"}
        For Each nm As String In nms
            If e.PostValues.ContainsKey(nm) = False Then
                e.WriteString("请输入" & nm & "!") '返回错误消息
                Return '必须返回
            End If
        Next
        Dim dr As DataRow = DataTables("订单").AddNew()
        For Each nm As String In nms
            dr(nm) = e.PostValues(nm)
        Next
        dr.Save()
        e.WriteString("OK") '返回增加成功消息
End Select

狐表文件订单表,有3列,分别是单价、数量、价格,并且设置公式单价*数量=价格。现在想在手机端录入单价和价格,点击确定后,则在价格方框内调取狐表端的价格计算结果并显示在手机端,望老师指点。

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109720 积分:558310 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/12/22 8:28:00 [只看该作者]

js添加一个函数

function calc(){
    document.getElementById("jiage").innerText = document.getElementById("数量").value * document.getElementById("单价").value;
}

addnew页面
……
       With wb.AddDialog("","dlg1", "提示","增加数据完成,是否生成价格?") 
            .AddButton("btnYes","是").Attribute = "onclick='calc();'想点击是则自动计算出价格处的数值。
            .AddButton("btnNo","否","http://www.foxtable.com").Kind = 1
        End With
        With wb.AddDialog("","dlg2", "错误","") '增加订单失败提示框
            .AddButton("btnOK","确定")
        End With
wb.InsertHTML("<h3 id='jiage' align='center' style='margin-top:5px'></h3>")
        wb.AppendHTML("<script src='./lib/ajaxform.js'></script>") '引入脚本文件
        e.WriteString(wb.Build)

 回到顶部
帅哥哟,离线,有人找我吗?
ycs5801
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1064 积分:7581 威望:0 精华:0 注册:2009/6/24 9:44:00
  发帖心情 Post By:2021/12/22 9:02:00 [只看该作者]

这个价格在狐表中已经计算好了,能不能直接提取狐表中的价格列中的数据?

 回到顶部
帅哥哟,离线,有人找我吗?
ycs5801
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1064 积分:7581 威望:0 精华:0 注册:2009/6/24 9:44:00
  发帖心情 Post By:2021/12/22 9:11:00 [只看该作者]

就是类似这个刷新按钮。
图片点击可在新窗口打开查看此主题相关图片如下:201791515164141391.jpg
图片点击可在新窗口打开查看

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109720 积分:558310 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/12/22 9:52:00 [只看该作者]

这样整个逻辑是不合理的。没有单号之类的东西,在提示框的确定按钮的时候,根据什么查之前新增的数据?

反正价格已经计算了,就没有必要在多个对话框问用户需不需要计算了吧,不如直接显示算了
function myfunction(){
    var result = submitAjaxForm('form1','',false);
if(result){
        var vals=result.split("|");
        if(vals.length==2 && 
vals[0] == "OK"){
            document.getElementById("价格").value=vals[1];
        }
    }
    else {showDialog('dlg2','错误',result)}
}

Select Case e.Path
    Case "addnew.htm"
        Dim wb As New weui
        wb.AddForm("","form1","handle.htm") '指定接收表单数据的的页面为handle.htm
        With wb.AddInputGroup("form1","ipg1","新增订单")
          
            .AddInput("数量","数量","number")
            .AddInput("单价","单价","number").Step = 0.1
            .AddInput("价格","价格","number")
        End With
        With wb.AddButtonGroup("form1","btg1",True)
            .Add("btn1", "确定", "button").Attribute= ""
        End With
        With wb.AddDialog("","dlg2", "错误","增加订单失败") '增加订单失败提示框
            .AddButton("btnOK","确定")
        End With
        wb.AppendHTML("<script src='./lib/ajaxform.js'></script>") '引入脚本文件
        e.WriteString(wb.Build)

  Case "handle.htm"
        Dim nms() As String = {"数量","单价"}
        For Each nm As String In nms
            If e.PostValues.ContainsKey(nm) = False Then
                e.WriteString("请输入" & nm & "!") '返回错误消息
                Return '必须返回
            End If
        Next
        Dim dr As DataRow = DataTables("订单").AddNew()
        For Each nm As String In nms
            dr(nm) = e.PostValues(nm)
        Next
        dr.Save()
        e.WriteString("OK|" & (dr(“数量”) * dr(“单价”))) '返回增加成功消息
End Select


 回到顶部
帅哥哟,离线,有人找我吗?
ycs5801
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1064 积分:7581 威望:0 精华:0 注册:2009/6/24 9:44:00
  发帖心情 Post By:2021/12/22 10:18:00 [只看该作者]

对的,没有必要要那个对话框了。我其实就想要一个类似计算器的功能,上边两个方框输入单价和数量,下边一个方框是价格,点击按钮计算,价格方框显示结果,但是这个结果是从狐表对应的行提取出来的。

 回到顶部
帅哥哟,离线,有人找我吗?
ycs5801
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1064 积分:7581 威望:0 精华:0 注册:2009/6/24 9:44:00
  发帖心情 Post By:2021/12/22 10:42:00 [只看该作者]

最后这句能不能改成:e.WriteString("OK|" & (dr(“价格”)))            
这样就直接从狐表中提取数据了。

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109720 积分:558310 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/12/22 11:01:00 [只看该作者]

可以

 回到顶部
帅哥哟,离线,有人找我吗?
ycs5801
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1064 积分:7581 威望:0 精华:0 注册:2009/6/24 9:44:00
  发帖心情 Post By:2021/12/22 13:55:00 [只看该作者]

 if(vals.length==2 && vals[0] == "OK"){      这句为什么要判断一下长度等于2呢?

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109720 积分:558310 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/12/22 14:30:00 [只看该作者]

比如出错了,或者没有数据返回,就不赋值了

 回到顶部
总数 41 1 2 3 4 5 下一页