.net嵌入c#代码(投票练习)

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <style type="text/css">
        * {
            margin:0px;
            padding:0px;
        }
    </style>
</head>
<body>
    <form id="form1" runat="server">
    <div>

        <asp:Label ID="lblTitle" runat="server"></asp:Label>
        <br />
        <br />
        <div id="vote">
            <asp:CheckBoxList ID="CheckBoxList1" runat="server">
            </asp:CheckBoxList>
            <br />
            <br />
            <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="提交" />
&nbsp
         <input type="button" value="查看结果" onclick="xianshi()" />
        </div>
        <div id="result" style="display:none">
            <ul style="list-style:none; margin-left:20px;">
                <%
                    TestDataContext context = new TestDataContext();
                    var query = context.DiaoYanXuanXiang.Where(p=>p.TiMuDaiHao == 1).ToList();

                    int sum = query.Sum(p => p.Numbers).Value;

                    foreach (DiaoYanXuanXiang data in query)
                    {

                        int ps = data.Numbers.Value;

                        double bfb = ((ps * 1.0) / sum) * 100;

                        double width = bfb * 2;

                     %>
                      <li style="width:600px; height:20px; margin-top:10px;">
                          <div style="width:150px; height:20px; float:left"><%=data.Options %></div>
                          <div style="width:200px; height:20px; background-color:gray; float:left">
                              <div style="width:<%=width%>px; height:20px; background-color:red"></div>
                          </div>
                          <div style ="width:20px; height:20px; float:left"><%=ps %></div>
                          <div style="width:80px; height:20px; float:left">(<%=bfb %>%)</div>
                      </li>

                <%
                    }
                     %>
            </ul>
            <input type="button" value="返回" onclick="fanhui()" />
        </div>

    </div>
    </form>
    <script type="text/javascript">
        function fanhui() {
            document.getElementById("vote").style.display = "block";
            document.getElementById("result").style.display = "none";
        }
        function xianshi() {

            document.getElementById("vote").style.display = "none";
            document.getElementById("result").style.display = "block";
        }
    </script>
</body>
</html>

aspx.cs代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            TestDataContext context = new TestDataContext();

            //查询题目
            var query = context.DiaoYanTiMu.Where(p=>p.Ids==1);
            //显示题目名称
            lblTitle.Text = query.First().Title;

            //显示题目选项
            CheckBoxList1.DataSource = context.DiaoYanXuanXiang.Where(p=>p.TiMuDaiHao == query.First().Ids);
            CheckBoxList1.DataTextField = "Options";
            CheckBoxList1.DataValueField = "Ids";
            CheckBoxList1.DataBind();
        }

    }
    protected void Button1_Click(object sender, EventArgs e)
    {
        //取投票的项,将票数更改
        TestDataContext context = new TestDataContext();
        foreach (ListItem ck in CheckBoxList1.Items)
        {
            if (ck.Selected)
            {
                var query = context.DiaoYanXuanXiang.Where(p=>p.Ids == Convert.ToInt32( ck.Value));

                query.First().Numbers += 1;

                context.SubmitChanges();
            }
        }

    }
}

二.使用< Script ></ Script >在HTML中嵌入C#代码

首先我们来看一看在HTML页面中嵌入JavaScript脚本程序的格式:

<SCRIPT LANGUAGE="JavaScript">

"JavaScript代码内容"
//JavaScript注释内容

</SCRIPT>
   为了通知浏览器使用的代码是JavaScript代码,必须在<SCRIPT>标记中加入LANGUAGE="JavaScript"属性。JavaScript代码一般以下面的形式包括在HTML代码中:其中,<script>标记是声明这是一个脚本程序,LANGUAGE是声明该脚本是一个Javascript 脚本。在<script>至</script>中间的任何内容都被视为脚本语句,会被浏览器解释执行。

我们用记事本编写一个HTML文件JavaScriptEx.html,代码如下:

<HTML>

<HEAD>

<TITLE>响应事件</TITLE>

</HEAD>

<BODY>

<SCRIPT LANGUAGE="JavaScript">

function aler(){

window.alert("这是JavaScript事件响应的例子");

}

</SCRIPT>

<INPUT TYPE="BUTTON" VALUE="触发按钮" ONCLICK="aler()">

</BODY>

</HTML>

保存后直接点击生成的.html文件即可在IE浏览器中运行,单击“触发按钮”后将弹出对话框,结果如下:

而对于同ASP.NET,除了<% %>标记,也可以使用<Script></ Script >标记用于在HTML中标记指令代码。对于ASP.NET,<Script>标记有两个特殊的属性:Language和Runat=”Server”。

1>     Language:该属性用于指定 <Script></ Script >之间代码所使用的编程语言,默认为Visual Basic.NET。另外,这里指定的语言必须与ASPX页首行使用的<%@ Page Language="…"%>一致,否则编译错误,这表明ASP.NET虽然支持多种编程语言,但在同一页面上只能使用一种语言。

2>     Runat=”Server”属性用于指定代码运行的位置是在服务器端。<Script></ Script >常常用于定义各种变量和函数,完成一定的功能。下面的示例是使用<Script></ Script >标记结合<% %>,根据当前日期输出不同的语句。

创建一个新的ASP.NET Web应用程序,打开ASPX页面Default.aspx,首先在<title> </title>之间添加标题“使用Script和%在HTML中嵌入C#“,在其中的<div> </div>标签中间输入以下代码:

<title>使用Script和%在HTML中嵌入C#</title>

<div>

    <!--这是HTML注释方式-->

    <%--

    <script>和</script>实现一个函数fun1,该函数根据当前星期,返回不同的日程安排。

    这是ASP.NET的注释方式

    --%>

    <script language="C#" runat="server">

    String fun1(string day)

    {

        string plan = "";/*C,C++,C#注释方式*/

        switch (day)

        {

            case "Monday":

                plan = "向客户提案!";

                break;

            case "Thuseday":

                plan = "参加霏霏的生日!";

                break;

            case "Wednesday":

                plan = "shopping!";

                break;

            case "Thursday":

                plan = "去健身房!";

                break;

            case "Friday":

                plan = "向老板汇报工作!";

                break;

            default:

                plan = "周末狂欢!";

                break;               

        }

        return plan;   

    }

    </script>

    <%--

    <% %>调用函数fun1,根据当前星期,显示日程安排。

    --%>

    <%

        string date = System.DateTime.Today.Date.ToString();

        string weekday = System.DateTime.Today.DayOfWeek.ToString();

        string output = fun1(weekday);//C,C++,C#注释方式

        Response.Write("现在是"+date+","+weekday+",我计划"+output);       

         %>    </div>

运行结果如下:

利用以上两种方法可以将C#代码嵌入到HTML中,形成ASPX动态网页文件,但是这样的页面语法混杂,难以管理,针对这个问题,ASP.NET提出了代码分离的思想:即把代码文件(C#代码)和页面显示代码(HTML代码)分离在不同的文档中,各自独立完成Web页面的逻辑功能和显示功能。然后通过<%@ CodeFile=…%>将两者绑定在一起,以达到C#代码嵌入到HTML中的效果。

Default.aspx的第一行解析:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<%@ Page …%>用来设置页面属性,各属性意义如下:

CodeFile="Default.aspx.cs"这个属性指定了隐藏在这个页面后面的代码文件,所要实现的功能代码就在Default.aspx.cs文件中。

Language="C#|VB"设置本页所采用的编程语言是C#,默认为C#

AutoEventWireup="true|false"是否使用ASP.NET约定的事件命名规则,为控件事件命名。

Inherits="…"定义公应用程序类继承的代码隐藏类

ResponseEdcodeing="…"设置ASPX编码方式,默认为Unicode。

Trace="true|false"设置是否在程序中显示代码直行的跟踪信息。

TraceMode="SortType"设置跟踪信息的排序方式,默认为根据执行时间顺序排序,“SortByTime”。

时间: 2024-10-27 12:48:40

.net嵌入c#代码(投票练习)的相关文章

使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 选择调用的进程为 24 i386 getuid sys_getuid1647 i386 getgid sys_getgid16 使用库函数API方式 使用C代码中嵌入汇编代码方式

实验--使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用(杨光)

使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 攥写人:杨光  学号:20135233 ( *原创作品转载请注明出处*) ( 学习课程:<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实验要求: 选择一个系统调用(13号系统调用time除外),系统调用列表参见http://codelab.shiyanlou.com/xref/linux-3.18.6/arch/x86/syscalls/sys

搁置挂起的更改 当代码不需要嵌入现有代码,但又想服务器赞为保存的时候

如何查找之前的搁置集? 点击操作->查找搁置集(F) 如何获得搁置代码到本地进行合并? 右键查找到的搁置集的名字->取消搁置 搁置挂起的更改 当代码不需要嵌入现有代码,但又想服务器赞为保存的时候,布布扣,bubuko.com

腾讯视频嵌入网页的方法 腾讯视频嵌入网页代码

首先,提供一个腾讯视频嵌入网页代码.我们只需替换这段代码的一部分就可以了. <p style="text-align: center"><iframe class="video_iframe" style="z-index:1;" src="http://v.qq.com/iframe/player.html?vid=t01662frswa&width=500&height=375&auto=0

实验四:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

/* getpid.c */ #include <unistd.h> #include <stdio.h> int main() { pid_t pid; pid = getpid(); printf("pid = %d \n",pid); return 0; } 上面是使用函数库API 运行结果: 下面是嵌入汇编代码: /* getpid_asm.c */ #include <unistd.h> #include <stdio.h> i

在smarty模板中嵌入php代码

我个人并不太喜欢smarty的语法,写起来比较啰嗦易出现匹配出错,但是旧项目中有许多工程都是采用它作模板.最近需要在此上稍微加一些PHP的内容,但我不想在模板控制层去一个一个assign,而想在模板文件中直接嵌入PHP的代码. 搜索了一下smarty中确实有直接使用PHP代码的标签,是 {php}//PHP语句 echo 'yes';{/php} 于是便用上它了.但注意这是默认的方式,如果你自定制了smarty标签的定界符,那么也得将{ 和 }进行相对应的改动. 我看到有些是用<?  ?>作定

用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

姓名:王晨光 学号:20133232 王晨光 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 本周的实验相比较前面3次实验较为容易理解,这次实验的浅析了系统调用的工作过程,通过用库函数API和C代码嵌入汇编代码两种方式使用同一个系统调用. 我这次实验选择了20号系统调用getpid来获取进程ID.首先我先在网上查阅了getpid函数是用来获取目前进程的ID,许多程序利用取到的此值

Webform中Repeater控件--绑定嵌入C#代码四种方式

网页里面嵌入C#代码用的是<% %>,嵌入php代码<?php ?> 绑定数据的四种方式: 1.直接绑定 <%#Eval("Code") %> 2.调用函数 <%#ShowSex()%> 3.显示外键关系列 <%#Eval("Nation1.Name") %> 4.格式化显示 <%#Eval("Birthday","{0:yyyy年MM月dd日}") %>

在使用&lt;script&gt;嵌入JavaScript代码时,不要在代码中的任何地方出现&quot;&lt;/script&gt;&quot;字符串

在使用<script>嵌入JavaScript代码时,记住不要在代码中的任何地方出现"</script>"字符串.例如浏览器执行下面代码会报错: <script type="text/javascript"> function sayHello() { console.log("</script>"); } </script> 浏览器会报以下错误:Uncaught SyntaxError