demo项目开发笔录(web和mobile)

笔者在demo里使用的样式文件是w3.css,支持响应式,但笔者前端能力有限,并不能一次编写统一使用,于是对访问作了判断,并删减了移动端页面的部分内容。

一、判断是移动端还是PC端的请求:

package com.gcc.modules.untils;

/**
 * Created by gcc on 2018/5/4.
 */
public class IsMobileUtil {
    private final static String[] agent = { "Android", "iPhone", "iPod","iPad", "Windows Phone", "MQQBrowser" }; //定义移动端请求的所有可能类型
    /**
     * 判断User-Agent 是不是来自于手机,false则是web
     * @param ua
     * @return
     */
    public static boolean checkAgentIsMobile(String ua) {
        boolean flag = false;
        if (!ua.contains("Windows NT") || (ua.contains("Windows NT") && ua.contains("compatible; MSIE 9.0;"))) {
            // 排除 苹果桌面系统
            if (!ua.contains("Windows NT") && !ua.contains("Macintosh")) {
                for (String item : agent) {
                    if (ua.contains(item)) {
                        flag = true;
                        break;
                    }
                }
            }
        }
        return flag;
    }
}

二、判断后,修改view

    /**
     * 首页
     * @param model
     * @return
     */
    @RequestMapping("index")
    public String index(Model model, HttpServletRequest request){

        String userAgent = request.getHeader("User-Agent");
        String view = "modules/frontstage/index";
        if(IsMobileUtil.checkAgentIsMobile(userAgent)){
            view="modules/frontstage/mobile/indexMobile";
        }

        String typeId = request.getParameter("typeId");
//        String id = request.getParameter("id");
        String pagination = request.getParameter("pagination");
        String flag = request.getParameter("flag");
        Map<String,Object> commentMap=indexService.getList(typeId,pagination,flag);
        model.addAttribute("articleList",commentMap.get("articleList"));
        model.addAttribute("pagination",commentMap.get("pagination"));
        List<ArticleType> articleTypeList=articleTypeService.getTypeList();
        model.addAttribute("articleTypeList",articleTypeList);
        model.addAttribute("typeId",typeId);
        return view;
    }

注:userAgent值示例:



三、微调页面比例,结果如下:

web:


mobile:




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值