站内搜索

搜索

手游源码-游戏源码-棋牌源码资源网-亲测源码-游戏搭建-破解游戏-网站源码-qq技术

100金币/天 购买
100金币/天 购买

APP来说访问行为的解析与解析路径(一)——forweb

11

主题

228

帖子

256

金币

绿钻会员

Rank: 3Rank: 3

积分
591
发表于 2022-3-1 12:00:55 | 显示全部楼层 |阅读模式
关于forweb的导航 通常对于传统网站来说访问行为是让一个HTML地址对应一个页面资源,而对于APP来说内部的多个页面是通过代码指令耦合的,整个APP实际上是一个资源。随着应用规模的扩大原本通过指令进行页面跳转的模式被抽取归纳统一为路由跳转。随着的发展与结合为协议路由统一跳转与状态传递的方式。 中的页面导航使用''进行url提取工具,在应用内部导航的方式比较自由,指令或者命名或者根据已有规范统一到中走中心路由的架构都可以随自己应用的体量来选择。 拦截URL 使用:可以截获通过URL获取路由的路径,在forweb中这里就可以截获在浏览器地址中输入的链接中index地址后面的部分 image

    void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
  const MyApp({Key key}) : super(key: key);
@override
Widget build(BuildContext context) {
  return MaterialApp(
   title: "main",
      debugShowCheckedModeBanner: false,
      onGenerateRoute:  onGenerateRoute,
  );
}
}
Route onGenerateRoute(RouteSettings settings) {
  String routeName = settings.name;
//根据地址跳转不同的页面
  if (routeName.contains('/artical')) {
      //截取参数
    String arg = "";
    if(routeName.length > 10){
      arg =  routeName.substring(9,routeName.length);
    }
    return MaterialPageRoute(builder: (context) { return HomeWidget(arguments: arg,); });
  } else if (routeName.contains('/tool')) {
    return MaterialPageRoute(builder: (context) { return ToolsPage(); });
  }else if (routeName.contains('/quote')) {
    return MaterialPageRoute(builder: (context) { return KlinePage(); });
  }else{
    return  MaterialPageRoute(builder: (context) { return HomeWidget(); });
  }
}

("#")问题 由于forweb是作为的形式存在因此对于浏览器来说,无论进行多少次内部跳转仍然在一个页面内。 nginx以#为分界解析路径。通过判别获取url路径给进行拦截获取参数。对于单页面或者内嵌来说这对访问不会造成任何影响。但如果要通过URL访问指定的页面会在一些情况下无法访问。 隐藏自动添加的"/#/" 如果只需要通过根路径访问网站。此时会自动将"/#/"拼接在地址栏中 image 如果希望去除#有两种方法 1.阻止自动添加# 可以从从项目中删除向地址栏添加#的代码。 首先build项目,然后找到构建的项目的main.dart.js文件并打开搜索'#'+a找到

    we:function(a){return a.length===0?H.b(window.location.pathname)+H.b(window.location.search):"#"+a},

删除"#"+。 image 2.向浏览器添加一个新的URL

      html.window.history.pushState(null, "flutter", "/");

配合NGINX重定向使用URL导航 如果需要使用URL通过浏览器在webapp内导航则需要使用的机制向APP传递地址信息,此时若想要在导航链路中排除"#",需要配合地址重定向和html...来手动构建导航体系。 通过NGINX添加重定向 image 获取路径后Push访问路经 image 如果是访问有连接后缀的地址会被调用两次,第一次是传入空置进去url提取工具,第二次才会传入地址栏中的地址。因此在没有收到后缀的地址中不能否则会屏蔽掉后续的重定向内容导致链接跳转失效。 过程大致如图 image 在这个方案下天外神坛源码网,页面导航与Nginx地址解析实际上是深度绑定了NGINX需要重定向所有应用中进浏览器的地址。而如果使用了CDN加速会导致重定向失效 通过浏览器获取URL进行导航 在无法处置NGINX重定向来协助导航的情况下,只能根据浏览器这一使用场景做特殊处理。让实例自己获取当前URL去做导航。使用html..获取当前访问的地址。而NGINX只需要将所有有导航目的地的路径都指向根目录就行了。 NGINX: image : image 最后如果设置了一些特殊的NGINX规则如二级路径有可能导致中无法找到图片资源。因此建议使用远端资源。
【天外神坛】免责声明及帮助
1.重要:如果遇到隐藏内容回复后显示为代码状态,直接刷新一下页面即可解决此问题。
2.本文部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责。
3.若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4.如果本站有侵犯、不妥之处的资源,请在网站右边客服联系我们。将会第一时间解决!
5.本站所有内容均由互联网收集整理、网友上传,仅供大家参考、学习,不存在任何商业目的与商业用途。
6.本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

上个主题 下个主题 快速回复 返回列表 客服中心 搜索 QQ加群
上个主题 下个主题 快速回复 返回列表 客服中心 搜索 QQ加群

QQ|Archiver|小黑屋|天外神坛

湘ICP备2021015333号

Powered by 天外神坛 X3.4 © 2020-2022 天外神坛