- 解决 ECharts 组件中多个 ID 重复问题
啃火龙果的兔子
开发DEMOjavascript开发语言
在封装ECharts组件时,如果多个组件实例使用相同的id="myChart"会导致DOM冲突,ECharts无法正确渲染。以下是几种解决方案:方案1:使用动态ID(推荐)//React示例functionMyChartComponent(){constchartId=useRef(`chart-${Math.random().toString(36).substr(2,9)}`);useEffe
- 如何创建唯一的 key 或者 ID
L?z ^f my
utilsjavascript前端
javaScript中创建唯一的key/***生成一个永不重复的key*@param{Number}randomLength*/functiongetUuiKey(randomLength=5){returnNumber(Math.random().toString().substr(2,randomLength)+Date.now()).toString(36)}
- 瑞芯微RK3506工业芯片实例方案解析:从架构到场景的深度实践
淡远-九鼎创展科技
架构嵌入式硬件人工智能电脑
一、芯片技术架构解析瑞芯微RK3506作为2024年第四季度推出的工业级MPU,采用三核Cortex-A7(1.5GHz)+单核Cortex-M0(200MHz)的异构架构,形成独特的"3+1"处理核心组合。这种设计通过AMP多核调度技术,实现了Linux、RTOS、Bare-metal系统的混合运行,典型配置如"2×A7运行Linux(HMI交互)+1×A7运行RTOS(协议处理)+M0裸机(实
- java随机生成1到33数组,JAVA 生成随机数数组
迷失的憨批
java随机生成1到33数组
一、JAVA获取随机数的方法//使用java.lang.Math类的random()方法doublea=Math.random();System.out.println("0.0-1.0的随机数:"+a);doubleb=Math.random()*100;System.out.println("0.0-100.0的随机数:"+b);intc=(int)(Math.random()*100);Sy
- Python 标准库之 math 模块
Json19970108018
Python进阶应用教程pythonwindows网络
1.前言math模块中包含了各种浮点运算函数,包括:函数功能floor向下取整ceil向上取整pow指数运算fabs绝对值sqrt开平方modf拆分小数和整数fsum计算列表中所有元素的累加和copysign复制符号pi圆周率e自然对数2.math.floor(n)函数math.floor(n)的功能是对浮点数n向下取整,示例如下:>>>importmath>>>math.floor(1.5)1>
- Java 常用类 Math:从“如何生成随机密码”讲起
炎码工坊
java
「炎码工坊」技术弹药已装填!点击关注→解锁工业级干货【工具实测|项目避坑|源码燃烧指南】一、问题驱动:为什么需要Math类?场景1:生成随机密码假设你要开发一个注册系统,需要生成一个6位随机数字密码。你会怎么做?// 方案1:使用 Math.random()int password = (int)(Math.random() * 900000) + 100000;System.out.printl
- C++经典题目,初学者快速入门!【附有解析】
文章目录题目一:1-100各类数之和(1)求1+2+3+...+100的和(2)求1+3+5+...+99的奇数和(3)求1+1/2+1/3+...+1/100的和(4)求-1+1/2-1/3+1/4...-1/99+1/100的和题目二:斐波那契数列(FibonacciSequence)又称黄金分割数列题目三:判断素数暴力法开根号法题目四:打印九九乘法表题目五:猴子爬杆(1)猴子每天爬3米,再向
- 【React】useId
秀秀_heo
React及其周边生态react.jsjavascript前端
在React中,useId是React18引入的一个Hook,用于生成一个在组件生命周期中保持稳定的唯一ID。它主要用于:无障碍(accessibility)场景,比如表单控件需要一个id和label的htmlFor属性配对。服务端渲染(SSR)与客户端渲染保持一致。避免多个组件生成的ID冲突。为什么不用自己写id?以前开发者会自己写逻辑生成id,比如用Math.random()、Date.now
- element-ui 在el-dialog中使用el-checkbox的一些坑
weixin_58195884
uivue.jsjavascript
js中只需要改变keyTable的值就行了,每次点击更新一次keyTablechangeRead(e,i){this.keyTable=Math.random()//Math.random()是获取一个随机小数来代替key值},
- MVC项目验证码的生成
qq_17060989
MVC学习笔记
目录前端调用控制器验证码图片生成类WebHelperMd5加密前端调用html代码换一张js代码$("#switchCode").click(function(){$("#imgcode").attr("src","/Login/GetValidateCode?"+Math.random())})$("#imgcode").click(function(){$("#imgcode").attr("
- node js 整除问题
Go高并发架构_王工
nodejs学习nodejsjsjavascriptlinuxvscode
在JavaScript中所有的数都是用double表示的,因此当你用a/b时,如果无法整除则会出现小数。举个例子:leta=5,b=3;console.log(a/b);输出如下:1.6666666666666667那么我们想要整除应该怎么办呢?可以使用Math.floor这个函数来完成。举个例子:leta=5,b=2;console.log(Math.floor(a/b));输出如下:2还有更多
- 如何使用 HTML、CSS 和 JavaScript 随机更改图片颜色
爱编程的鱼
算法结构HTMLhtmlcssjavascript
原文:如何使用HTML、CSS和JavaScript随机更改图片颜色|w3cschool笔记(请勿标记为付费!!!!)在网页开发中,为图片添加动态效果可以显著提升用户体验。今天,我将向大家介绍如何通过HTML、CSS和JavaScript实现图片颜色的随机更改。这个教程不仅简单易懂,还能帮助你理解前端开发中的交互式设计原理。方法一:使用Math.random()函数示例代码随机更改图片颜色|编程狮
- 【前端】Vue中使用CKeditor作为富文本编辑器
普通老人
前端前端vue.jsjavascript
官网https://ckeditor.com/此处记录一下我在使用的时候具体初始化的代码。exportdefault{name:'CkEditor',data:function(){return{id:parseInt(Math.random()*10000).toString(),ckeditor:null,};},//初始化mounted:function(){constself=this;l
- 牛客周赛 Round 54 解题
green qwq
牛客算法图论
清楚姐姐的糖葫芦代码#includeusingnamespacestd;stringa;intres;intmain(){cin>>a;for(inti=0;i#defineintlonglongusingnamespacestd;inta,b,x;signedmain(){cin>>a>>b>>x;intres;if(3*a>=b){if(x%3*a>=b){res=(x/3+1)*b;}els
- python 常见函数_Python 10个常用函数
weixin_30273263
python常见函数
round函数#四舍五入保留小数后两位IN[0]:round(3.146,2)OUT[0]:3.15floor函数importmath#向下取整IN[1]:math.floor(3.14)OUT[1]:3ceil函数#向上取整IN[2]:math.ceil(3.14)OUT[2]:4range函数#生成序列In[3]:list(range(10,1,-2))Out[3]:[10,8,6,4,2]m
- [NOIP 2003 普及组] 麦森数 Java
heyCHEEMS
java开发语言
importjava.util.*;importjava.math.BigInteger;publicclassMain{publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);intp=sc.nextInt();sc.close();intnum=(int)Math.floor(p*Math.log10(2))+1;/
- 在Python中对一个数取整
胡同Alley
python
1.向下取整使用math.floor()函数可以将一个数向下取整,即取不大于该数的最大整数。importmathnum=3.7result=math.floor(num)print(result)#输出3对于负数,math.floor()会取更小的整数:num=-3.7result=math.floor(num)print(result)#输出-42.向上取整使用math.ceil()函数可以将一
- 用java实现猜数字游戏
AIGC_北苏
游戏p2pjava
/*如何和用户进行猜数字(10到99的整数)游戏?思路:Math类型获得随机数:Math.random()--->可以返回一个double类型的随机数且范围为[0,1.0)doublenember=Math.random()*90+10;--->获得一个[10,100.0)的随机数number强制类型转换intnumber1=(int)(Math.random()*90+10);--->获得一个[
- LLM三角原则解析:简化大模型应用开发的秘籍
大模型入门学习
人工智能数据库产品经理AI大模型大模型开源
先前我们聊到了《从零开始构建大模型(LLM)应用》,不少朋友偷偷问我:“什么是LLM的三角原则?”今天就给大家仔细讲讲构建LLM应用的三角原则。这套原则其实不复杂,由“3+1”(一范式三原则)个基础组成,适合任何团队来实践。说到以LLM为核心的应用,有不少人以为是高大上的模型占主导,但其实情况是这样的:10%是那些复杂的模型,而有足足90%是实验性的、以数据为驱动的工程作业。当我们把LLM应用到实
- React中使用useMemo对计算结果进行缓存
开发者小天
react.js缓存前端
//引入React的useState、memo和useMemoAPIimport{useState,memo,useMemo}from'react';//使用memo包裹Header组件以优化渲染性能//memo会阻止组件在props不变时不必要的重新渲染constHeader=memo(functionHeader(){return(//Math.random()用于演示组件是否被重新渲染hel
- 前端实现试卷题目、选项打乱。
Rlm*
JavaScript前端javascript
选项打乱//定义原始选项数组varoptions=["选项1","选项2","选项3","选项4"];//将选项数组复制到新数组中varnewOptions=[...options];//打乱选项数组for(leti=newOptions.length-1;i>0;--i){constj=Math.floor(Math.random()*(i+1));//生成[0,i]之间随机索引[newOpti
- 异步无刷新分页[一般处理程序处理]的简单思路
weixin_30410999
json数据库
-1.load事件之后执行loadAjax()方法:$(function(){loadAjax(1);});0.在loadAjax()方法中:functionloadAjax(pageIndex){$("#p").text("正在加载sssssssssssss");//发送异步请求//$.getJSON("PhotosList.ashx?_="+Math.random(),function(msg
- Java中随机数生成
liuliyydsnb
javapython开发语言
在Java中生成随机数可以通过多种方法实现,以下是常见的几种方式及其适用场景:一、基础方法:Random类与Math.random()使用java.util.Random类通过实例化Random对象调用方法生成不同类型随机数:Randomrandom=newRandom();intrandomInt=random.nextInt();//生成任意范围内的整数intrangedInt=random.
- three.js中使用canvas生成动态纹理贴图
VcB之殇
javascriptthree.js
three.js小白的学习之路。今天分享一个使用canvas生成纹理,然后通过CanvasTexture类创建贴图的例子。1.canvas纹理生成一个圆形的canvas纹理,颜色随机,半径随机,圆心随机。先创建一个随机函数:constrand=(min:number,max:number)=>{return(Math.random()*(max-min)+min)|0;};Math.random(
- java编写随机程序,随机生成10道一百以内的加减法
不归路&
Javajavaeclipse
Java随机生成10道一百以内的加减法利用Java随机编程输出10道一百以内的加减法在这里插入代码片publicstaticvoidmain(String[]args){Scannerinput=newScanner(System.in);for(inti=0;i<10;i++){inta=(int)(Math.random()*100+1);intminus=(int)(Math.random(
- 前端技巧——性能优化篇
小二爱编程·
前端性能优化
开题之前,思考以下三个性能比较:for循环和for循环哪个更快?Math.floor是否比|0更好?多个if-else是否要用switch-case替代? 前端发展至此,前端性能随之变成了一个很有意思的话题。从入门级别的初级工程师,到高级别的专家,都离不开性能问题。那么前端性能该如何理解呢?总论 前端时间学习前淘宝前端总负责人winter的课程,受益颇深。前面三个性能比较的例子,在社区或者论坛
- uni-app实现拼多多倒计时拼团
Carrie_zzz
前端uni-app拼多多倒计时拼团滚动
(xx)效果图?(1)倒计时方法其中self是我传入的uni-app中的this。self.assembleData则为数组===》一个个团exportfunctioncountTime(self){lettimer=setInterval(function(){for(leti=0;i0){letday=Math.floor(t/86400000)lethour=Math.floor((t/36
- Python基础paddlepaddle
愚昧之山绝望之谷开悟之坡
PaddlePaddleNLP基础知识python
print(math.ceil(4.1))#返回数字的上入整数print(math.floor(4.9))#返回数字的下舍整数字符串单引号、双引号、三引号print(‘HelloWorld!’)print(“HelloWorld!”)转义字符\print(“The\tisatab”)print(‘I’mgoingtothemovies’)TheisatabI’mgoingtothemovies三引
- opengl--圆锥和圆柱光照和纹理
一片云略过
unity虚拟现实opengl图形学shader
圆锥和圆柱光照和纹理由于在圆锥的侧面中和底面圆中,重合的底面圆上的点的法向量是不同的,同时在纹理贴图时候,必有在同一个圆上位置,此处有两个顶点,其中一个的纹理索引是起始点,另一个是终点。若将底面圆类在实现时,等同于被分为m个线段,则圆锥总的顶底需要一个底面圆心+底面圆周的点+侧面扇形上顶点+等同于m的圆锥顶点。即共需要顶点(m+1)*3+1个。法向量和纹理:在圆锥中:顶点数组中,索引为1到m+1个
- Java开发入门-数组和方法以及补充
子柒s
java开发语言
标题目录数组数组的定义数组的初始化静态初始化动态初始化数组的访问数组的遍历/迭代数组的复制使用循环手动复制(最基础)使用System.arraycopy()(高效推荐)使用Arrays.copyOf()方法方法的意义方法的定义方法的调用return方法的重载(overloading)补充随机数的生成方式Math.random()方法(最基础)Random类(最常用)Debug调试工具默认值数组数组
- 多线程编程之卫生间
周凡杨
java并发卫生间线程厕所
如大家所知,火车上车厢的卫生间很小,每次只能容纳一个人,一个车厢只有一个卫生间,这个卫生间会被多个人同时使用,在实际使用时,当一个人进入卫生间时则会把卫生间锁上,等出来时打开门,下一个人进去把门锁上,如果有一个人在卫生间内部则别人的人发现门是锁的则只能在外面等待。问题分析:首先问题中有两个实体,一个是人,一个是厕所,所以设计程序时就可以设计两个类。人是多数的,厕所只有一个(暂且模拟的是一个车厢)。
- How to Install GUI to Centos Minimal
sunjing
linuxInstallDesktopGUI
http://www.namhuy.net/475/how-to-install-gui-to-centos-minimal.html
I have centos 6.3 minimal running as web server. I’m looking to install gui to my server to vnc to my server. You can insta
- Shell 函数
daizj
shell函数
Shell 函数
linux shell 可以用户定义函数,然后在shell脚本中可以随便调用。
shell中函数的定义格式如下:
[function] funname [()]{
action;
[return int;]
}
说明:
1、可以带function fun() 定义,也可以直接fun() 定义,不带任何参数。
2、参数返回
- Linux服务器新手操作之一
周凡杨
Linux 简单 操作
1.whoami
当一个用户登录Linux系统之后,也许他想知道自己是发哪个用户登录的。
此时可以使用whoami命令。
[ecuser@HA5-DZ05 ~]$ whoami
e
- 浅谈Socket通信(一)
朱辉辉33
socket
在java中ServerSocket用于服务器端,用来监听端口。通过服务器监听,客户端发送请求,双方建立链接后才能通信。当服务器和客户端建立链接后,两边都会产生一个Socket实例,我们可以通过操作Socket来建立通信。
首先我建立一个ServerSocket对象。当然要导入java.net.ServerSocket包
ServerSock
- 关于框架的简单认识
西蜀石兰
框架
入职两个月多,依然是一个不会写代码的小白,每天的工作就是看代码,写wiki。
前端接触CSS、HTML、JS等语言,一直在用的CS模型,自然免不了数据库的链接及使用,真心涉及框架,项目中用到的BootStrap算一个吧,哦,JQuery只能算半个框架吧,我更觉得它是另外一种语言。
后台一直是纯Java代码,涉及的框架是Quzrtz和log4j。
都说学前端的要知道三大框架,目前node.
- You have an error in your SQL syntax; check the manual that corresponds to your
林鹤霄
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'option,changed_ids ) values('0ac91f167f754c8cbac00e9e3dc372
- MySQL5.6的my.ini配置
aigo
mysql
注意:以下配置的服务器硬件是:8核16G内存
[client]
port=3306
[mysql]
default-character-set=utf8
[mysqld]
port=3306
basedir=D:/mysql-5.6.21-win
- mysql 全文模糊查找 便捷解决方案
alxw4616
mysql
mysql 全文模糊查找 便捷解决方案
2013/6/14 by 半仙
[email protected]
目的: 项目需求实现模糊查找.
原则: 查询不能超过 1秒.
问题: 目标表中有超过1千万条记录. 使用like '%str%' 进行模糊查询无法达到性能需求.
解决方案: 使用mysql全文索引.
1.全文索引 : MySQL支持全文索引和搜索功能。MySQL中的全文索
- 自定义数据结构 链表(单项 ,双向,环形)
百合不是茶
单项链表双向链表
链表与动态数组的实现方式差不多, 数组适合快速删除某个元素 链表则可以快速的保存数组并且可以是不连续的
单项链表;数据从第一个指向最后一个
实现代码:
//定义动态链表
clas
- threadLocal实例
bijian1013
javathreadjava多线程threadLocal
实例1:
package com.bijian.thread;
public class MyThread extends Thread {
private static ThreadLocal tl = new ThreadLocal() {
protected synchronized Object initialValue() {
return new Inte
- activemq安全设置—设置admin的用户名和密码
bijian1013
javaactivemq
ActiveMQ使用的是jetty服务器, 打开conf/jetty.xml文件,找到
<bean id="adminSecurityConstraint" class="org.eclipse.jetty.util.security.Constraint">
<p
- 【Java范型一】Java范型详解之范型集合和自定义范型类
bit1129
java
本文详细介绍Java的范型,写一篇关于范型的博客原因有两个,前几天要写个范型方法(返回值根据传入的类型而定),竟然想了半天,最后还是从网上找了个范型方法的写法;再者,前一段时间在看Gson, Gson这个JSON包的精华就在于对范型的优雅简单的处理,看它的源代码就比较迷糊,只其然不知其所以然。所以,还是花点时间系统的整理总结下范型吧。
范型内容
范型集合类
范型类
- 【HBase十二】HFile存储的是一个列族的数据
bit1129
hbase
在HBase中,每个HFile存储的是一个表中一个列族的数据,也就是说,当一个表中有多个列簇时,针对每个列簇插入数据,最后产生的数据是多个HFile,每个对应一个列族,通过如下操作验证
1. 建立一个有两个列族的表
create 'members','colfam1','colfam2'
2. 在members表中的colfam1中插入50*5
- Nginx 官方一个配置实例
ronin47
nginx 配置实例
user www www;
worker_processes 5;
error_log logs/error.log;
pid logs/nginx.pid;
worker_rlimit_nofile 8192;
events {
worker_connections 4096;}
http {
include conf/mim
- java-15.输入一颗二元查找树,将该树转换为它的镜像, 即在转换后的二元查找树中,左子树的结点都大于右子树的结点。 用递归和循环
bylijinnan
java
//use recursion
public static void mirrorHelp1(Node node){
if(node==null)return;
swapChild(node);
mirrorHelp1(node.getLeft());
mirrorHelp1(node.getRight());
}
//use no recursion bu
- 返回null还是empty
bylijinnan
javaapachespring编程
第一个问题,函数是应当返回null还是长度为0的数组(或集合)?
第二个问题,函数输入参数不当时,是异常还是返回null?
先看第一个问题
有两个约定我觉得应当遵守:
1.返回零长度的数组或集合而不是null(详见《Effective Java》)
理由就是,如果返回empty,就可以少了很多not-null判断:
List<Person> list
- [科技与项目]工作流厂商的战略机遇期
comsci
工作流
在新的战略平衡形成之前,这里有一个短暂的战略机遇期,只有大概最短6年,最长14年的时间,这段时间就好像我们森林里面的小动物,在秋天中,必须抓紧一切时间存储坚果一样,否则无法熬过漫长的冬季。。。。
在微软,甲骨文,谷歌,IBM,SONY
- 过度设计-举例
cuityang
过度设计
过度设计,需要更多设计时间和测试成本,如无必要,还是尽量简洁一些好。
未来的事情,比如 访问量,比如数据库的容量,比如是否需要改成分布式 都是无法预料的
再举一个例子,对闰年的判断逻辑:
1、 if($Year%4==0) return True; else return Fasle;
2、if ( ($Year%4==0 &am
- java进阶,《Java性能优化权威指南》试读
darkblue086
java性能优化
记得当年随意读了微软出版社的.NET 2.0应用程序调试,才发现调试器如此强大,应用程序开发调试其实真的简单了很多,不仅仅是因为里面介绍了很多调试器工具的使用,更是因为里面寻找问题并重现问题的思想让我震撼,时隔多年,Java已经如日中天,成为许多大型企业应用的首选,而今天,这本《Java性能优化权威指南》让我再次找到了这种感觉,从不经意的开发过程让我刮目相看,原来性能调优不是简单地看看热点在哪里,
- 网络学习笔记初识OSI七层模型与TCP协议
dcj3sjt126com
学习笔记
协议:在计算机网络中通信各方面所达成的、共同遵守和执行的一系列约定 计算机网络的体系结构:计算机网络的层次结构和各层协议的集合。 两类服务: 面向连接的服务通信双方在通信之前先建立某种状态,并在通信过程中维持这种状态的变化,同时为服务对象预先分配一定的资源。这种服务叫做面向连接的服务。 面向无连接的服务通信双方在通信前后不建立和维持状态,不为服务对象
- mac中用命令行运行mysql
dcj3sjt126com
mysqllinuxmac
参考这篇博客:http://www.cnblogs.com/macro-cheng/archive/2011/10/25/mysql-001.html 感觉workbench不好用(有点先入为主了)。
1,安装mysql
在mysql的官方网站下载 mysql 5.5.23 http://www.mysql.com/downloads/mysql/,根据我的机器的配置情况选择了64
- MongDB查询(1)——基本查询[五]
eksliang
mongodbmongodb 查询mongodb find
MongDB查询
转载请出自出处:http://eksliang.iteye.com/blog/2174452 一、find简介
MongoDB中使用find来进行查询。
API:如下
function ( query , fields , limit , skip, batchSize, options ){.....}
参数含义:
query:查询参数
fie
- base64,加密解密 经融加密,对接
y806839048
经融加密对接
String data0 = new String(Base64.encode(bo.getPaymentResult().getBytes(("GBK"))));
String data1 = new String(Base64.decode(data0.toCharArray()),"GBK");
// 注意编码格式,注意用于加密,解密的要是同
- JavaWeb之JSP概述
ihuning
javaweb
什么是JSP?为什么使用JSP?
JSP表示Java Server Page,即嵌有Java代码的HTML页面。使用JSP是因为在HTML中嵌入Java代码比在Java代码中拼接字符串更容易、更方便和更高效。
JSP起源
在很多动态网页中,绝大部分内容都是固定不变的,只有局部内容需要动态产生和改变。
如果使用Servl
- apple watch 指南
啸笑天
apple
1. 文档
WatchKit Programming Guide(中译在线版 By @CocoaChina) 译文 译者 原文 概览 - 开始为 Apple Watch 进行开发 @星夜暮晨 Overview - Developing for Apple Watch 概览 - 配置 Xcode 项目 - Overview - Configuring Yo
- java经典的基础题目
macroli
java编程
1.列举出 10个JAVA语言的优势 a:免费,开源,跨平台(平台独立性),简单易用,功能完善,面向对象,健壮性,多线程,结构中立,企业应用的成熟平台, 无线应用 2.列举出JAVA中10个面向对象编程的术语 a:包,类,接口,对象,属性,方法,构造器,继承,封装,多态,抽象,范型 3.列举出JAVA中6个比较常用的包 Java.lang;java.util;java.io;java.sql;ja
- 你所不知道神奇的js replace正则表达式
qiaolevip
每天进步一点点学习永无止境纵观千象regex
var v = 'C9CFBAA3CAD0';
console.log(v);
var arr = v.split('');
for (var i = 0; i < arr.length; i ++) {
if (i % 2 == 0) arr[i] = '%' + arr[i];
}
console.log(arr.join(''));
console.log(v.r
- [一起学Hive]之十五-分析Hive表和分区的统计信息(Statistics)
superlxw1234
hivehive分析表hive统计信息hive Statistics
关键字:Hive统计信息、分析Hive表、Hive Statistics
类似于Oracle的分析表,Hive中也提供了分析表和分区的功能,通过自动和手动分析Hive表,将Hive表的一些统计信息存储到元数据中。
表和分区的统计信息主要包括:行数、文件数、原始数据大小、所占存储大小、最后一次操作时间等;
14.1 新表的统计信息
对于一个新创建
- Spring Boot 1.2.5 发布
wiselyman
spring boot
Spring Boot 1.2.5已在7月2日发布,现在可以从spring的maven库和maven中心库下载。
这个版本是一个维护的发布版,主要是一些修复以及将Spring的依赖提升至4.1.7(包含重要的安全修复)。
官方建议所有的Spring Boot用户升级这个版本。
项目首页 | 源