卡厄思
梦
境
菜单
首页
回到首页
WIKI工具
全站样式
全站JS
修改导航栏
测试
沙盒
可视化管理器
战斗员管理器
卡牌管理器
伙伴管理器
装备管理器
词典管理器
图鉴
战斗员
伙伴
装备
怪物卡牌
中立卡牌
词典
小工具
配队模拟器
节奏榜生成器
搜索
链入页面
相关更改
特殊页面
页面信息
最近更改
登录
模块
查看“︁装备”︁的源代码
←
模块:装备
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
local p = {} local data = mw.loadData('模块:装备/data') -- 获取装备稀有度对应的中文 local rarityMap = { ["蓝"] = "蓝", ["紫"] = "紫", ["金"] = "金" } -- 生成装备卡片 function p.card(frame) local args = frame.args local name = args[1] or args.name local level = args[2] or args.level or "1" if not name or not data[name] then return "装备不存在: " .. (name or "未指定") end local equip = data[name] local base = equip.base local levelData = equip[level] if not levelData then return "装备等级不存在: " .. level end -- 生成HTML local html = mw.html.create('div') :addClass('equipment-card') :attr('data-equipment', name) :attr('data-level', level) :cssText('position: relative; display: inline-block; width:150px; height: 230px; cursor: pointer;') -- 背景 html:tag('div') :cssText('position: absolute; top: 0px; left: 0px;') :wikitext(string.format('[[File:bg_equipment_rarity_%s.png|150px|link=]]', base.rarity)) -- 装备图片 html:tag('div') :cssText('position: absolute; top: 43px; left: 13px;') :wikitext(string.format('[[File:%s|124px|link=]]', base.art)) -- 底部背景 html:tag('div') :cssText('position: absolute; bottom: 5px; left: 5px; width: 140px; height: 35px; background-color: rgba(0,0,0,0.5); border-radius: 0px 0px 8px 8px') -- 星级 html:tag('div') :cssText('position: absolute; bottom: 10px; left: 20px;') :wikitext(string.format('[[File:icon_star_rating_%s.png|link=]]', level)) -- 顶层蒙版 html:tag('div') :cssText('position: absolute; top: 0px; left: 0px;') :wikitext('[[File:equipment_顶层蒙版.png|150px|link=]]') return tostring(html) end -- 生成装备详情弹窗 function p.popup(frame) local args = frame.args local name = args[1] or args.name local level = args[2] or args.level or "1" if not name or not data[name] then return "装备不存在: " .. (name or "未指定") end local equip = data[name] local base = equip.base local levelData = equip[level] if not levelData then return "装备等级不存在: " .. level end -- 处理描述文本 local desc = levelData.desc_global desc = string.gsub(desc, "{{文本|橙|([^}]+)}}", '<span style="color:#ff9500;">%1</span>') -- 生成HTML local html = mw.html.create('div') :addClass('equipment-popup') :attr('id', 'equipment-popup-' .. mw.uri.encode(name)) :cssText('position: relative; display: none; width:368px; height: 335px; background-color: #343434; border-radius: 9px') -- 背景 html:tag('div') :cssText('position: absolute; top: 0px; left: 0px;') :wikitext(string.format('[[File:bg_collection_rarity_%s.png|link=]]', base.rarity)) -- 装备图片 html:tag('div') :cssText('position: absolute; top: 40px; left: 128px;') :wikitext(string.format('[[File:%s|124px|link=]]', base.art)) -- 星级背景 html:tag('div') :cssText('position: absolute; top: 167px; left: 0px; width: 368px; height: 35px; background-color: rgba(0,0,0,0.5);') -- 星级 html:tag('div') :cssText('position: absolute; top: 173px; left: 128px;') :wikitext(string.format('[[File:icon_star_rating_%s.png|link=]]', level)) -- 类型图标 html:tag('div') :cssText('position: absolute; top: 205px; left: 5px; color: white') :wikitext(string.format('[[File:icon_equip_%s_%s.png|25px|link=]]', base.type, base.rarity)) -- 装备名称 html:tag('div') :cssText('position: absolute; top: 209px; left: 33px; color: white') :wikitext(name) -- 属性背景 html:tag('div') :cssText('position: absolute; top: 235px; left: 9px; width: 350px; height: 35px; background-color: rgba(255,255,255,0.3); border-radius: 2px') -- 属性类型 html:tag('div') :cssText('position: absolute; top: 242px; left: 14px; color: white') :wikitext(base.value_type) -- 属性值 html:tag('div') :cssText('position: absolute; top: 242px; right: 14px; color: white') :wikitext(levelData.value) -- 描述 html:tag('div') :cssText('position: absolute; top: 277px; left: 10px; right: 10px; color: white; font-size: 14px;') :wikitext(desc) -- 关闭按钮 html:tag('div') :addClass('equipment-popup-close') :cssText('position: absolute; top: 10px; right: 10px; width: 24px; height: 24px; cursor: pointer; color: white; font-size: 20px;') :wikitext('×') return tostring(html) end -- 生成装备完整展示(卡片+弹窗) function p.show(frame) local cardHtml = p.card(frame) local popupHtml = p.popup(frame) local wrapper = mw.html.create('div') :addClass('equipment-wrapper') :cssText('display: inline-block; position: relative;') :wikitext(cardHtml) :wikitext(popupHtml) return tostring(wrapper) end -- 生成装备卡片列表(用于筛选页面) function p.generateCards(frame) local html = mw.html.create() -- 遍历所有装备,生成5星卡片 for equipName, equipData in pairs(data) do local base = equipData.base local level5 = equipData["5"] if level5 then -- 只显示有5星的装备 -- 创建可筛选的卡片容器 local cardWrapper = html:tag('div') :addClass('divsort equipment-wrapper') -- 添加equipment-wrapper类 :attr('data-param1', rarityMap[base.rarity] or base.rarity) -- 稀有度 :attr('data-param2', base.area) -- 区域 :attr('data-param3', base.tag) -- TAG(多个用逗号分隔) :cssText('display: inline-block; margin: 5px; position: relative;') -- 生成卡片内容 local cardDiv = cardWrapper:tag('div') :addClass('equipment-card') :attr('data-equipment', equipName) :attr('data-level', '5') :cssText('position: relative; display: inline-block; width:150px; height: 230px; cursor: pointer;') -- 背景 cardDiv:tag('div') :cssText('position: absolute; top: 0px; left: 0px;') :wikitext(string.format('[[File:bg_equipment_rarity_%s.png|150px|link=]]', base.rarity)) -- 装备图片 cardDiv:tag('div') :cssText('position: absolute; top: 43px; left: 13px;') :wikitext(string.format('[[File:%s|124px|link=]]', base.art)) -- 底部背景 cardDiv:tag('div') :cssText('position: absolute; bottom: 5px; left: 5px; width: 140px; height: 35px; background-color: rgba(0,0,0,0.5); border-radius: 0px 0px 8px 8px') -- 星级 cardDiv:tag('div') :cssText('position: absolute; bottom: 10px; left: 20px;') :wikitext('[[File:icon_star_rating_5.png|link=]]') -- 顶层蒙版 cardDiv:tag('div') :cssText('position: absolute; top: 0px; left: 0px;') :wikitext('[[File:equipment_顶层蒙版.png|150px|link=]]') -- 生成对应的弹窗 local popupDiv = cardWrapper:tag('div') :addClass('equipment-popup') :attr('id', 'equipment-popup-' .. mw.uri.encode(equipName)) :cssText('position: relative; display: none; width:368px; height: 335px; background-color: #343434; border-radius: 9px') -- 弹窗背景 popupDiv:tag('div') :cssText('position: absolute; top: 0px; left: 0px;') :wikitext(string.format('[[File:bg_collection_rarity_%s.png|link=]]', base.rarity)) -- 弹窗装备图片 popupDiv:tag('div') :cssText('position: absolute; top: 40px; left: 128px;') :wikitext(string.format('[[File:%s|124px|link=]]', base.art)) -- 星级背景 popupDiv:tag('div') :cssText('position: absolute; top: 167px; left: 0px; width: 368px; height: 35px; background-color: rgba(0,0,0,0.5);') -- 星级 popupDiv:tag('div') :cssText('position: absolute; top: 173px; left: 128px;') :wikitext('[[File:icon_star_rating_5.png|link=]]') -- 类型图标 popupDiv:tag('div') :cssText('position: absolute; top: 205px; left: 5px; color: white') :wikitext(string.format('[[File:icon_equip_%s_%s.png|25px|link=]]', base.type, base.rarity)) -- 装备名称 popupDiv:tag('div') :cssText('position: absolute; top: 209px; left: 33px; color: white') :wikitext(equipName) -- 属性背景 popupDiv:tag('div') :cssText('position: absolute; top: 235px; left: 9px; width: 350px; height: 35px; background-color: rgba(255,255,255,0.3); border-radius: 2px') -- 属性类型 popupDiv:tag('div') :cssText('position: absolute; top: 242px; left: 14px; color: white') :wikitext(base.value_type) -- 属性值 popupDiv:tag('div') :cssText('position: absolute; top: 242px; right: 14px; color: white') :wikitext(level5.value) -- 处理描述文本 local desc = level5.desc_global desc = string.gsub(desc, "{{文本|橙|([^}]+)}}", '<span style="color:#ff9500;">%1</span>') -- 描述 popupDiv:tag('div') :cssText('position: absolute; top: 277px; left: 10px; right: 10px; color: white; font-size: 14px;') :wikitext(desc) -- 关闭按钮 popupDiv:tag('div') :addClass('equipment-popup-close') :cssText('position: absolute; top: 10px; right: 10px; width: 24px; height: 24px; cursor: pointer; color: white; font-size: 20px;') :wikitext('×') end end return tostring(html) end return p
该页面使用的模板:
模块:装备/doc
(
查看源代码
)
返回
模块:装备
。