html静态页面动态加载c#数据

html-css019

html静态页面动态加载c#数据,第1张

反射的作用:

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