1.一文搞清到底什么是项目项目 NET
2.网页音乐播放器HTML源码
3.MVC框架Mvc控件
一文搞清到底什么是 NET
其实几句话就能搞清楚.net。
我们知道我们使用C#/VB写的源码代码是源码,如果这个源码你写在记事本中也是项目项目一样的。
然后使用csc.exe/vbc.exe把你的源码源码编译。生成的项目项目文件就是IL文件(可能为dll或exe后缀的)。
事实上,源码建德源码开发我们如果在记事本写是项目项目一样的,这个记事本叫编辑器,源码你需要一句句地把代码写出来。项目项目如果我们记事本象notepad+一样能带一个高亮语法的源码标识多好?当然了,如果能有自动补全更好(一个关键词或声明的项目项目变量之类的,打出几个字母就提示出来,源码我们可以提高输入速度的项目项目,录入速度与打字速度这里有区别了,源码很多程序员以为自己输入速度很高,项目项目进而以为自己的打字速度很高,其实不是我经常说程序打字速度并不快不需要机械键盘就是因为这个,并不是说输入速度低),这些功能都加上,就是VS(vs其实是一个IDE,开发集成工具,而编辑器就是其中一个,智能感智——自动补全功能加强版,djangomodel源码高亮显示等都是编辑器的插件被集成进来),而模板(自动给你增加using代码与部分文件名称等等)则是把常用的一些句子先给你输入好,等等集合起来,就把编辑这部分完成了。
当然了,你安装完之后会看到类似于csc.exe与vbc.exe这类的编译器的,它可以把你的源码(文本)编译成IL语言。不幸的是csc/vbc的参数太多了,输出输入选项等等,谁也记不住啊,所以根据文本组织,自动生成一个csc参数使用的命令多好?嗯,想法不错的,这就是VS中另一个功能,他所谓有的编译F6等等都是按你的项目组织自动生成一条编译指令来调用编译器(csc编译c#的,vbc编译vb的),VS不但可以自已选择合适的编译器(根据后缀名),而且对于项目中某个参数,自动调用csc.
好了,怎么把源码变成IL呢?这里要用到一个东西,我们叫.net framework,不要把framework理解成模板,jem源码不要以为你选择.net framework版本之后可以选择不同的模板,其实它才是把源码变成IL的标准——模板不同是因为针对于不同的语法糖进行不同的翻译。比如一个例子using语句块其实就是try-finally块,不同的framework中使用不同的类库与语法糖。换句话来说,开发中所增加的都是使用基本类库与语法糖的增加。
比如.net framework 4.5中存在一个运算符,(?.)运算,它就会在.net framework 4.5时会映射到正确的IL语言。而在.net framework 4.0中却不会认识该运算符。当然了 vari?.Attribute1与.net framework 4.0中vari==null?null:vari.Attribute1的结果是一样的。虽然.net framework 4.5比4.0增加了不少的东西,它其实只是方便了你写的源码,IL指令并没有任何的增加!
所以呢每当.net framework版本增加时,其实只变化了一些我们编码时的语法或语法糖而已!并附带送给我们几个模板或新开发几个模板而已。比如MVC/web api等等模板。
说完了生成,现在再说一下IL是怎么运行的,IL其实并不能直接运行,我们需要一个标准把IL再"映射“成可运行的exobot源码二进制(机器语言),源码”映射“成IL使用的是.net framework,而IL映射成二进制需要的是.net,不同的是我们把源码”映射“IL叫编译,使用的是.net framework,也叫编译态,而IL映射成二进制并运行,这个叫运行态。所以我们称两个的区别一个叫开发环境,一个叫运行环境。如果按照正常的理解,其实我们一个用的是.net framework 4.X,运行时我们安装的dotnet4f,是运行环境。
运行环境的虚拟机就是为了把IL映射成二进制(Native Image),而且我们会保存起来,当然了,下次使用相同的IL时,直接使用Native Image中已保存的,不再执行翻译了,这个就是运行时的机制。
大多数时间很多人把开发环境与运行环境弄混了,为什么呢?因为我们开发时避免不了要测试及运行,jcanvas源码所以开发环境包含了运行环境(你安装.net framework时同时会安装运行环境),而不需要开发的人员比如如使用windows 中已经安装了部分的.net 运行环境支持,所以他们也不需要了解这个东西。只在在出现类似.net framework 4.0在vista版本中运行时,就需要给vista非开发机安装.net framework运行版本。否则不需要。所以很多人把开发环境与运行环境混在一起理解了。
事实上,.net framework 2.0/3.5开发的软件,生成了IL标准都是2.0的,所以我们只需要2.0的运行环境。而.net 4.0及4.x.y都使用的是.net 4.0的运行环境。
说白了,.net有开发版本,而framework相当于编译时使用的标准。而IL的标准则是MSIL,也叫是我们常说的CLS,而把运行态叫CLR(公共语言运行时)是虚拟机要执行的标准。
所以,其概况非常简单,.net支持多种语言,多种语言都是可以生成IL依赖于不同的编译器,比如csc/vbc等。可以让不同的语言开发者在同平台下工作。而IL(中间语言)再由虚拟机在不同的机器上翻译成不同的机器语言,保证了其移植性。包括现在支持的linux新标准也是如此方式。跨平台则使用是native image方式。
分清这两个步骤,那么.net就没有什么神密的了。
告诉你几个事实,有助于理解问题。
C#生成的IL可以被反射成VB语法!当然反向也可以!Red gate的reflector已被MS收购。可以试试的,原来的ILDism已被基本放弃了!它是早期做为VS的插件工具出现的。当然ILSpy也是不错的,那只是一个反射工具而已。请细想为什么C#生成的IL可以反射成VB语言(反射的准确度与各家软件的功能有一定的关系)
.net framework 4.0的生成的IL可以被反射成4.7.2的语法!想想这是为什么?如果你运行环境与编译环境搞混的话,假定IL中也有4.7.2的运行环境,那么怎么可能版本之间相互反射?但是,.net 2.0生成的IL反射成.net 4.0会存在问题,.net 4.0生成的IL反射成2.0会会现很多错误!其实.net 4.0并不包含.net 2.0的语法集,所以这两个运行版本并不兼容,反射软件只会把相同的部分反射出来,不同的部分就难以反映了!.net 2.0反射4.0的结果要好点,这是因归功于.net framework为了降低学习成本,有一定的连续性,但是这种连续性在高版中部分.开发使用的C#语法被放弃(放弃与清除是不同的,放弃还能反射出来,清除的却无法再反射了)。
搞清这些就能搞清楚.net的两段三步(两段开发段/运行段,三步,源码语法(C#/VB),IL语法(MSIL), 二进制(可运行的机器语言))。
网页音乐播放器HTML源码
1、实现ASP.Net MVC网页播放音乐html代码。2、实现控制音频播放、暂停还需要加入JS代码如下。
3、实现前台处理方法代码。
4、实现后台处理的方法代码。
5、支持HTML5浏览器效果1。
6、如果不支持HTML5浏览器效果如下。
MVC框架Mvc控件
在ASP.NET MVC框架中,虽然没有自带的控件,但开发者可以通过HtmlHelper和UrlHelper这两个核心工具来处理页面显示。HtmlHelper位于System.Web.MVC.Html命名空间,它提供了如FormExtensions、InputExtensions、LinkExtensions等7个静态扩展类,分别用于处理CheckBox、Hidden、Pass、RadioButton、TextBox等控件的生成,以及链接的创建。LinkExtensions类则支持ActionLink和RouteLink方法,用于生成动作链接和路由链接。 UrlHelper则专注于URL的生成,包括Action方法生成带有Controller、Action和参数的URL,Content方法将虚拟路径转换为绝对路径,Encode方法加密URL,以及RouteUrl方法根据路由规则获取URL。类中还包含RequestContext和RouteCollection属性,分别表示HTTP上下文和路由数据,以及整个应用程序的路由规则。 虽然HtmlHelper能满足大部分开发需求,但在某些情况下,可能需要自定义控件。自定义控件的实现基于扩展HtmlHelper对象,需创建一个静态类和静态方法,如MyHtmlHelper的GetSpan方法,它接收HtmlHelper和文本参数,返回HTML标签。使用时,确保引用了扩展方法的命名空间,然后在页面中调用自定义方法。 对于那些自定义控件过于复杂或不切实际的项目,可以从技术社区或源代码平台寻找现成的Mvc控件,如控件套包和表格控件,以节省时间和精力。总的来说,ASP.NET MVC框架虽然基础控件较少,但借助辅助类和自定义扩展,开发人员能够灵活地构建页面并生成所需的HTML。扩展资料
MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用于组织代码用一种业务逻辑和数据显示分离的方法,这个方法的假设前提是如果业务逻辑被聚集到一个部件里面,而且界面和用户围绕数据的交互能被改进和个性化定制而不需要重新编写业务逻辑MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。