mirror of
https://github.com/zhwei820/learn.lianglianglee.com.git
synced 2025-11-15 21:53:50 +08:00
u
This commit is contained in:
@@ -25,13 +25,7 @@
|
||||
<meta name="generator" content="Hexo 4.2.0">
|
||||
|
||||
</head>
|
||||
|
||||
|
||||
|
||||
<body>
|
||||
|
||||
|
||||
|
||||
<div class="book-container">
|
||||
|
||||
<div class="book-sidebar">
|
||||
@@ -55,373 +49,190 @@
|
||||
<li><a href="/" class="current-tab">首页</a></li>
|
||||
|
||||
</ul>
|
||||
|
||||
|
||||
|
||||
<ul class="uncollapsible">
|
||||
|
||||
<li><a href="../">上一级</a></li>
|
||||
|
||||
</ul>
|
||||
|
||||
|
||||
|
||||
<ul class="uncollapsible">
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/00 生活中的设计模式:启程之前,请不要错过我.md.html">00 生活中的设计模式:启程之前,请不要错过我.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/01 监听模式:坑爹的热水器.md.html">01 监听模式:坑爹的热水器.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/02 适配模式:身高不够鞋来凑.md.html">02 适配模式:身高不够鞋来凑.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
<a class="current-tab" href="/专栏/白话设计模式 28 讲(完)/03 状态模式:人与水的三态.md.html">03 状态模式:人与水的三态.md.html</a>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/04 单例模式:你是我生命的唯一.md.html">04 单例模式:你是我生命的唯一.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/05 职责模式:我的假条去哪了.md.html">05 职责模式:我的假条去哪了.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/06 中介模式:找房子问中介.md.html">06 中介模式:找房子问中介.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/07 代理模式:帮我拿一下快递.md.html">07 代理模式:帮我拿一下快递.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/08 装饰模式:你想怎么穿就怎么穿.md.html">08 装饰模式:你想怎么穿就怎么穿.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/09 工厂模式:你要拿铁还是摩卡.md.html">09 工厂模式:你要拿铁还是摩卡.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/10 迭代模式:下一个就是你了.md.html">10 迭代模式:下一个就是你了.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/11 组合模式:自己组装电脑.md.html">11 组合模式:自己组装电脑.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/12 构建模式:想要车还是庄园.md.html">12 构建模式:想要车还是庄园.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/13 克隆模式:给你一个分身术.md.html">13 克隆模式:给你一个分身术.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/14 策略模式:怎么来不重要,人到就行.md.html">14 策略模式:怎么来不重要,人到就行.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/15 命令模式:大闸蟹,走起!.md.html">15 命令模式:大闸蟹,走起!.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/16 备忘模式:好记性不如烂笔头.md.html">16 备忘模式:好记性不如烂笔头.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/17 享元模式:颜料很贵必须充分利用.md.html">17 享元模式:颜料很贵必须充分利用.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/18 外观模式:学妹别慌,学长帮你.md.html">18 外观模式:学妹别慌,学长帮你.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/19 访问模式:一千个读者一千个哈姆雷特.md.html">19 访问模式:一千个读者一千个哈姆雷特.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/20 生活中的设计模式:与经典设计模式的不解渊源.md.html">20 生活中的设计模式:与经典设计模式的不解渊源.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/21 生活中的设计模式:那些未完待续的设计模式.md.html">21 生活中的设计模式:那些未完待续的设计模式.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/22 深入解读过滤器模式:制作一杯鲜纯细腻的豆浆.md.html">22 深入解读过滤器模式:制作一杯鲜纯细腻的豆浆.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/23 深入解读对象池技术:共享让生活更便捷.md.html">23 深入解读对象池技术:共享让生活更便捷.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/24 深入解读回调机制:把你技能亮出来.md.html">24 深入解读回调机制:把你技能亮出来.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/25 谈谈我对设计模式的理解.md.html">25 谈谈我对设计模式的理解.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/26 谈谈我对设计原则的思考.md.html">26 谈谈我对设计原则的思考.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
<li>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<a href="/专栏/白话设计模式 28 讲(完)/27 谈谈我对项目重构的看法.md.html">27 谈谈我对项目重构的看法.md.html</a>
|
||||
|
||||
|
||||
|
||||
</li>
|
||||
|
||||
</ul>
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<div class="sidebar-toggle" onclick="sidebar_toggle()" onmouseover="add_inner()" onmouseleave="remove_inner()">
|
||||
|
||||
<div class="sidebar-toggle-inner"></div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script>
|
||||
|
||||
function add_inner() {
|
||||
@@ -431,9 +242,6 @@
|
||||
inner.classList.add('show')
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
function remove_inner() {
|
||||
|
||||
let inner = document.querySelector('.sidebar-toggle-inner')
|
||||
@@ -441,9 +249,6 @@
|
||||
inner.classList.remove('show')
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
function sidebar_toggle() {
|
||||
|
||||
let sidebar_toggle = document.querySelector('.sidebar-toggle')
|
||||
@@ -473,9 +278,6 @@
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
function open_sidebar() {
|
||||
|
||||
let sidebar = document.querySelector('.book-sidebar')
|
||||
@@ -499,13 +301,7 @@ function hide_canvas() {
|
||||
overlay.classList.remove('show')
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
</script>
|
||||
|
||||
|
||||
|
||||
<div class="off-canvas-content">
|
||||
|
||||
<div class="columns">
|
||||
@@ -575,23 +371,14 @@ function hide_canvas() {
|
||||
<pre><code class="language-python">class Water:
|
||||
|
||||
"水(H2O)"
|
||||
|
||||
|
||||
|
||||
def __init__(self, state):
|
||||
|
||||
self.__temperature = 25
|
||||
|
||||
self.__state = state
|
||||
|
||||
|
||||
|
||||
def setState(self, state):
|
||||
|
||||
self.__state = state
|
||||
|
||||
|
||||
|
||||
def changeState(self, state):
|
||||
|
||||
if (self.__state):
|
||||
@@ -605,15 +392,9 @@ function hide_canvas() {
|
||||
print("初始化为", state.getStateName())
|
||||
|
||||
self.__state = state
|
||||
|
||||
|
||||
|
||||
def getTemperature(self):
|
||||
|
||||
return self.__temperature
|
||||
|
||||
|
||||
|
||||
def setTemperature(self, temperature):
|
||||
|
||||
self.__temperature = temperature
|
||||
@@ -629,111 +410,60 @@ function hide_canvas() {
|
||||
else:
|
||||
|
||||
self.changeState(GaseousState("气态"))
|
||||
|
||||
|
||||
|
||||
def riseTemperature(self, step):
|
||||
|
||||
self.setTemperature(self.__temperature + step)
|
||||
|
||||
|
||||
|
||||
def reduceTemperature(self, step):
|
||||
|
||||
self.setTemperature(self.__temperature - step)
|
||||
|
||||
|
||||
|
||||
def behavior(self):
|
||||
|
||||
self.__state.behavior(self)
|
||||
|
||||
|
||||
|
||||
class State:
|
||||
|
||||
"状态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
self.__name = name
|
||||
|
||||
|
||||
|
||||
def getStateName(self):
|
||||
|
||||
return self.__name
|
||||
|
||||
|
||||
|
||||
def behavior(self, water):
|
||||
|
||||
pass
|
||||
|
||||
|
||||
|
||||
class SolidState(State):
|
||||
|
||||
"固态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
super().__init__(name)
|
||||
|
||||
|
||||
|
||||
def behavior(self, water):
|
||||
|
||||
print("我性格高冷,当前体温", water.getTemperature(),
|
||||
|
||||
"摄氏度,我坚如钢铁,仿如一冷血动物,请用我砸人,嘿嘿……")
|
||||
|
||||
|
||||
|
||||
class LiquidState(State):
|
||||
|
||||
"液态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
super().__init__(name)
|
||||
|
||||
|
||||
|
||||
def behavior(self, water):
|
||||
|
||||
print("我性格温和,当前体温", water.getTemperature(),
|
||||
|
||||
"摄氏度,我可滋润万物,饮用我可让你活力倍增……")
|
||||
|
||||
|
||||
|
||||
class GaseousState(State):
|
||||
|
||||
"气态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
super().__init__(name)
|
||||
|
||||
|
||||
|
||||
def behavior(self, water):
|
||||
|
||||
print("我性格热烈,当前体温", water.getTemperature(),
|
||||
|
||||
"摄氏度,飞向天空是我毕生的梦想,在这你将看不到我的存在,我将达到无我的境界……")
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>测试代码:</p>
|
||||
@@ -765,9 +495,6 @@ class GaseousState(State):
|
||||
water.reduceTemperature(80)
|
||||
|
||||
water.behavior()
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>输出结果:</p>
|
||||
@@ -793,9 +520,6 @@ class GaseousState(State):
|
||||
由 液态 变为 固态
|
||||
|
||||
我性格高冷,当前体温 -20 摄氏度,我坚如钢铁,仿如一冷血动物,请用我砸人,嘿嘿……
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<h3>从剧情中思考状态模式</h3>
|
||||
@@ -845,17 +569,11 @@ class GaseousState(State):
|
||||
# 实际复杂应用场景中,可以将其单独定义成一个类
|
||||
|
||||
self.__stateInfo = 0
|
||||
|
||||
|
||||
|
||||
def addState(self, state):
|
||||
|
||||
if (state not in self.__states):
|
||||
|
||||
self.__states.append(state)
|
||||
|
||||
|
||||
|
||||
def changeState(self, state):
|
||||
|
||||
if (state is None):
|
||||
@@ -875,15 +593,9 @@ class GaseousState(State):
|
||||
self.addState(state)
|
||||
|
||||
return True
|
||||
|
||||
|
||||
|
||||
def getState(self):
|
||||
|
||||
return self.__curState
|
||||
|
||||
|
||||
|
||||
def _setStateInfo(self, stateInfo):
|
||||
|
||||
self.__stateInfo = stateInfo
|
||||
@@ -893,15 +605,9 @@ class GaseousState(State):
|
||||
if( state.isMatch(stateInfo) ):
|
||||
|
||||
self.changeState(state)
|
||||
|
||||
|
||||
|
||||
def _getStateInfo(self):
|
||||
|
||||
return self.__stateInfo
|
||||
|
||||
|
||||
|
||||
class State:
|
||||
|
||||
"状态的基类"
|
||||
@@ -909,29 +615,17 @@ class State:
|
||||
def __init__(self, name):
|
||||
|
||||
self.__name = name
|
||||
|
||||
|
||||
|
||||
def getStateName(self):
|
||||
|
||||
return self.__name
|
||||
|
||||
|
||||
|
||||
def isMatch(self, stateInfo):
|
||||
|
||||
"状态信息stateInfo是否在当前的状态范围内"
|
||||
|
||||
return False
|
||||
|
||||
|
||||
|
||||
def behavior(self, context):
|
||||
|
||||
pass
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<h4>类图</h4>
|
||||
@@ -947,9 +641,6 @@ class State:
|
||||
<pre><code class="language-python">class Water(Context):
|
||||
|
||||
"水(H2O)"
|
||||
|
||||
|
||||
|
||||
def __init__(self):
|
||||
|
||||
super().__init__()
|
||||
@@ -961,33 +652,18 @@ class State:
|
||||
self.addState(GaseousState("气态"))
|
||||
|
||||
self.setTemperature(25)
|
||||
|
||||
|
||||
|
||||
def getTemperature(self):
|
||||
|
||||
return self._getStateInfo()
|
||||
|
||||
|
||||
|
||||
def setTemperature(self, temperature):
|
||||
|
||||
self._setStateInfo(temperature)
|
||||
|
||||
|
||||
|
||||
def riseTemperature(self, step):
|
||||
|
||||
self.setTemperature(self.getTemperature() + step)
|
||||
|
||||
|
||||
|
||||
def reduceTemperature(self, step):
|
||||
|
||||
self.setTemperature(self.getTemperature() - step)
|
||||
|
||||
|
||||
|
||||
def behavior(self):
|
||||
|
||||
state = self.getState()
|
||||
@@ -995,9 +671,6 @@ class State:
|
||||
if(isinstance(state, State)):
|
||||
|
||||
state.behavior(self)
|
||||
|
||||
|
||||
|
||||
# 单例的装饰器
|
||||
|
||||
def singleton(cls, *args, **kwargs):
|
||||
@@ -1005,9 +678,6 @@ def singleton(cls, *args, **kwargs):
|
||||
"构造一个单例的装饰器"
|
||||
|
||||
instance = {}
|
||||
|
||||
|
||||
|
||||
def __singleton(*args, **kwargs):
|
||||
|
||||
if cls not in instance:
|
||||
@@ -1015,33 +685,18 @@ def singleton(cls, *args, **kwargs):
|
||||
instance[cls] = cls(*args, **kwargs)
|
||||
|
||||
return instance[cls]
|
||||
|
||||
|
||||
|
||||
return __singleton
|
||||
|
||||
|
||||
|
||||
@singleton
|
||||
|
||||
class SolidState(State):
|
||||
|
||||
"固态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
super().__init__(name)
|
||||
|
||||
|
||||
|
||||
def isMatch(self, stateInfo):
|
||||
|
||||
return stateInfo < 0
|
||||
|
||||
|
||||
|
||||
def behavior(self, context):
|
||||
|
||||
if (isinstance(context, Water)):
|
||||
@@ -1049,29 +704,17 @@ class SolidState(State):
|
||||
print("我性格高冷,当前体温", context.getTemperature(),
|
||||
|
||||
"摄氏度,我坚如钢铁,仿如一冷血动物,请用我砸人,嘿嘿……")
|
||||
|
||||
|
||||
|
||||
@singleton
|
||||
|
||||
class LiquidState(State):
|
||||
|
||||
"液态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
super().__init__(name)
|
||||
|
||||
|
||||
|
||||
def isMatch(self, stateInfo):
|
||||
|
||||
return (stateInfo >= 0 and stateInfo < 100)
|
||||
|
||||
|
||||
|
||||
def behavior(self, context):
|
||||
|
||||
if (isinstance(context, Water)):
|
||||
@@ -1079,29 +722,17 @@ class LiquidState(State):
|
||||
print("我性格温和,当前体温", context.getTemperature(),
|
||||
|
||||
"摄氏度,我可滋润万物,饮用我可让你活力倍增……")
|
||||
|
||||
|
||||
|
||||
@singleton
|
||||
|
||||
class GaseousState(State):
|
||||
|
||||
"气态"
|
||||
|
||||
|
||||
|
||||
def __init__(self, name):
|
||||
|
||||
super().__init__(name)
|
||||
|
||||
|
||||
|
||||
def isMatch(self, stateInfo):
|
||||
|
||||
return stateInfo >= 100
|
||||
|
||||
|
||||
|
||||
def behavior(self, context):
|
||||
|
||||
if (isinstance(context, Water)):
|
||||
@@ -1109,17 +740,11 @@ class GaseousState(State):
|
||||
print("我性格热烈,当前体温", context.getTemperature(),
|
||||
|
||||
"摄氏度,飞向天空是我毕生的梦想,在这你将看不到我的存在,我将达到无我的境界……")
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>这里只要改一下上面测试代码的第一行就可以了:</p>
|
||||
|
||||
<pre><code class="language-python">water = Water()
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>自己跑一下,会发现输出结果和之前的是一样的。</p>
|
||||
@@ -1163,9 +788,6 @@ class GaseousState(State):
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
@@ -1173,9 +795,6 @@ class GaseousState(State):
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<a class="off-canvas-overlay" onclick="hide_canvas()"></a>
|
||||
|
||||
</div>
|
||||
@@ -1191,17 +810,11 @@ class GaseousState(State):
|
||||
<script>
|
||||
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
|
||||
|
||||
|
||||
function gtag() {
|
||||
|
||||
dataLayer.push(arguments);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'G-NPSEEVD756');
|
||||
@@ -1227,9 +840,6 @@ class GaseousState(State):
|
||||
setCookie("lastPath", path)
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
function setCookie(cname, cvalue) {
|
||||
|
||||
var d = new Date();
|
||||
@@ -1241,9 +851,6 @@ class GaseousState(State):
|
||||
document.cookie = cname + "=" + cvalue + "; " + expires + ";path = /";
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
function getCookie(cname) {
|
||||
|
||||
var name = cname + "=";
|
||||
@@ -1261,12 +868,6 @@ class GaseousState(State):
|
||||
return "";
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
</script>
|
||||
|
||||
|
||||
|
||||
</html>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user