1. 可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型
2. 应用程序需要在运行时从某个特定的程序集中载入一个特定的类型,以便实现某个任务时可以用到反射。
3. 反射主要应用与类库,这些类库需要知道一个类型的定义,以便提供更多的功能。
1 需要反射的DLL
using System
namespace Webtest
{
public class ReflectTest
{
public ReflectTest(){}
public string WriteString(string s)
{
return "欢迎您," + s
}
//静态函数
public static string WriteName(string s)
{
return "欢迎您光临," + s
}
//不带参数的函数
public string WriteNoPara()
{
return "您使用的是无参数方法"
}
}
}
应用于反射的例子-在aspNET页面中加入以下函数:
public void test1()
{
System.Reflection.Assembly ass
Type type
object obj
try
{
ass =
System.Reflection.Assembly.LoadFile(@"d:\TestReflect.dll")//要绝对路径type = ass.GetType("Webtest.ReflectTest")//必须使用
名称空间+类名称System.Reflection.MethodInfo method =
type.GetMethod("WriteString")//方法的名称
obj =
ass.CreateInstance("Webtest.ReflectTest")//必须使用名称空间+类名称
string s = (string)method.Invoke(obj,new string[]{"jianglijun"})
// 实例方法的调用
或:string s = (string)method.Invoke(obj,Object[] parametors = new
Object[]{"param"})
Response.Write(s+"
")
method = type.GetMethod("WriteName")//方法的名称
s = (string)method.Invoke(null,new string[]{"jianglijun"})//
静态方法的调用
Response.Write(s+"
")
method = type.GetMethod("WriteNoPara")//无参数的实例方法
s = (string)method.Invoke(obj,null)
Response.Write(s+"
")
method = null
}
catch(Exception ex)
{
Response.Write(ex+"
")
}
finally
{
ass = null
type = null
obj = null
}
2、在窗体中加载DLL文件中的用户控件
点击按钮,在窗体的panel1控件中加载用户控件
private void button1_Click(object sender,
EventArgs e)
{
Assembly ass =
Assembly.LoadFrom(@"C:\Users\zhuochaoyou\Documents\Visual Studio
2010\Projects\class1\class1\obj\Debug\class1.dll")
object oClient =
(System.Windows.Forms.Control)ass.CreateInstance("class1.UserControl1",
true)")//必须使用 名称空间+用户控件类名称
this.panel1.Controls.Add((Control)oClient)
}
方法:1、直接贴图:在界面上贴一个gif动态等待效果图片,gif图片获取方式:网上找素材,会ps的可以自己制作<img src="wait.gif" />
2、CSS3/SVG/HTML5 Canvas手动绘制等待效果:
这种效果:网上有很多类似素材,可以根据需要选择,或使用上述技术绘制
下面提供一个CSS3绘制的范例
3、CSS的代码如下:
<style>
.loading {
width:0
height:0
border-right:20px solid #fff
border-top:20px solid #000
border-left:20px solid #fff
border-bottom:20px solid #000
border-radius: 20px
-moz-border-radius: 20px
-webkit-border-radius: 20px
}
.loading {
animation: bganim 0.6s linear 0s infinite
-moz-animation: bganim 0.6s linear 0s infinite
-webkit-animation: bganim 0.6s linear 0s infinite
}
@keyframes bganim {
from { transform:rotate(0deg)} to { transform:rotate(360deg)}
}
@-moz-keyframes bganim {
from { -moz-transform:rotate(0deg)} to { -moz-transform:rotate(360deg)}
}
@-webkit-keyframes bganim {
from { -webkit-transform:rotate(0deg)} to { -webkit-transform:rotate(360deg)}
}
</style>
4、<label>CSS3效果</label>,<div class="loading"></div>
效果如下图:运行机制很简单,先手动绘制一个静态的图,然后控制对应div进行360度旋转,即可实现
5、使用js等待效果插件(如:spin.js)
6、JS代码如下:
var opts = {
lines: 9,
length: 0,
width: 15,
radius: 20,
corners: 1,
rotate: 0,
direction: 1,
color: '#0101DF',
speed: 1,
trail: 34,
shadow: false,
hwaccel: false,
className: 'spinner',
zIndex: 2e9,
top: '50%',
left: '50%'
}
var target = document.getElementById('img_wait')
var spinner = new Spinner(opts).spin(target)
7、html代码的引用:<div id="img_wait"></div>
8、打开测试,效果如下
详细介绍:http://www.w3school.com.cn/jquery/ajax_load.asp
在当前html里写如下js:
$("#div1").load("test.html #div1")//把test.html里面id为div1的加载到当前页的div1
$("#div2").load("test.html #div2")//把test.html里面id为div2的加载到当前页的div2