spring boot 之如何在两个页面之间传递值

问题:页面之间的跳转,通常带有值的传输,但是,在现在比较流行的SPRING MVC WEB
开发模型中,设计机制导致页面之间的直接接跳转和传值不被支持(网上看到的,没有深究),
但是如果我么要实现两个页面之间传值怎么实现呢?

值的传递:
流程
将值name从A.html传给controller,让后读取这个值,增加到model里,然后,B.html从model中读取处理

A. html 如何将name值传过去
方法一:使用传统的方法,如下,

<a href=/controller_link?staff_name=?>

数据不重要并且数据不多时候,可以用,代码如下:

'</td><td><a href ="/attendance/calendar?staff_name='+ data.content[key].name +'"> ' + typeStyle(examine) + " </a> </td></tr>"

上面的格式不需要看,只是这是我的代码,这是一个例子,在这里使用javascript来构建table,如果需要看,则结合上下文来看,详细请看我的博文:JAVASCRIPT构建TABLE。

方法二:使用ajax,使用点击动作,点击后,调用ajax 函数,将函数传给controller,ajax使用普通的发送和接收数据格式:代码如下

 var staff_name2=$("#staff_name2").val();
      alert(staff_name2);
      $.ajax({
            type : 'get',
            url : "./getdatasrcInser",
            async : true,
            dataType : 'json',
            error: "重新请求",
            data:{
                'staff_name_new':staff_name2
            },
      Success:function(){},      
      Error:function(){}
});

url 是controller 中的一个Requestmapping链接。
下面是controller中代码,将获得到的参数,添加到controller要转到的B.html。

@RequestMapping("/calendar")
public String Calendar( Model model,@RequestParam(value = "staff_name", required = false, defaultValue = "") String staff_name) {


        /*List<CalendarTa> lists=calendarTaRepository.findAllByName("aa");
        model.addAttribute("lists", lists);*/
        model.addAttribute("staff_name", staff_name);
        return "B.html"
    }   

@直到staff_name代码部分表示获取传来的参数的部分,value表示传来的id,其他的一样就行(什么意思,现在也不知道),String staff_name 表示在这里被定义出来的形参。值和staff_name的值一样。

那么我们如何在B.html中获取staff_name属性的值呢?
两个方法:
方法一(最通用的方法)
思路:在HTML body中定义一个属性,或者标签什么都可以,给定id,或者属性什么都可以,按时要JAVASCRIPT 可以找的到。代码如下:

<input type="hidden" th:value="${staff_name}" id="staff_name2"/>

${staff_name} javascript,读取staff_name的值,然后在javascript中读取出id为staff_name2的值,其代码如下:

var staff_name2=$("#staff_name2").val();

剩下就可以使用staff_name了。
方法二:涉及到Thymeleaf 的使用,上面的th:value 也使用到了thymeleaf,普通的只要value就可以了。
代码如下,不要设计属性,可以直接引用下面的代码就可以了

<script th:inline="javascript">
   /*<![CDATA[*/
   var staff_name = /*[[${staff_name}]]*/;
   /*]]>*/
   </script>

只需改变staff_name到你定义的属性名称就可以,当然前提是得知道如何使用thymeleaf。

  • 12
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值