消息关闭
    暂无新消息!
首先,客户要自定义一个表单

如上图所示

做过商城的童鞋们应该都接触过,就是拓展字段,数据库里存显示名称,字段名称,存储类型,输入类型等等
下面贴数据库表和记录



下面说需求
图一里,最后一个输入类型是“事件单选框”,
再贴一张图举例

上图的 取票方式 就是事件单选框
当选择自取的时候,快递方式和联系人地址这两个隐藏

这是一个比较简单的例子,如果只实现这种效果,倒也简单
实际需求是,取票方式是事件单选,快递方式也是事件单选,还可能更深层次的嵌套,所以我的思路就行不通了

下面讲讲我目前的思路,虽说不能很好的实现,但也勉强能用
我现在是把这些自定义的字段放到一个容器里面(div里),然后记录事件单选框点击每个选项时需要隐藏和显示的字段的index值,然后生成页面的时候,根据那个index值生成JS代码。
不知道我描述的清楚不,不懂下面回复。

这种思路如果在表单不能自定义排序和没有多层嵌套的前提下是OK的,
一旦重新定义了表单的排序,那么对应的index值就会变,就会和数据库里的对应不上
而多层嵌套,我反复实验,总是会有缺陷

所以不得已来这里跟大神大仙讨教

5个回答

︿ 3
<div id="div1"> radio_id1,radio_id2,radio_id3</div>
<div id="div2" data-show="div1_radio_id1,div1_radio_id2" data-hide="div1_radio_id3"></div>
<div id="div3" data-show="div1_radio_id3" data-hide="div1_radio_id1,div1_radio_id2"></div>
然后点击事件里用js  显示/隐藏 div
︿ 0
而且我看你文中说到难点是排序以及嵌套.

那么用这个"文本编辑器" 就不会出现任何你的问题了..因为完全是自定义想加什么就加什么...

跟我们看到的"文本编辑器"不同的是.. 除了这些常用的东西之外.还有一些"表单"按钮 

比如插入文本框 插入复选框 插入其他表单....当然这些东西 在百度的ue下都是支持二次开发的.

所以我觉得这种"自定义"表单用这种方式 比你那种要灵活不仅仅是一个次元...
︿ 0
给单选(id?name?)加guid,对应的div(id?)也加相同的guid,单选事件中 把 包含相同guid的隐藏(或显示)

︿ 0
在ASP.NET 的早先版本里,开发人员通过在页面的顶部添加 <%@ Register %> 指令来引入和使用自定义服务器控件和用户控件时,象这样:

 

<%@ Register TagPrefix="scott" TagName="header" Src="Controls/Header.ascx" %>
<%@ Register TagPrefix="scott" TagName="footer" Src="Controls/Footer.ascx" %>
<%@ Register TagPrefix="ControlVendor" Assembly="ControlVendor" %>

<html>
<body>
    <form id="form1" runat="server">
        <scott:header ID="MyHeader" runat="server" />
    </form>
</body>
</html>
注意到上面的前两个注册指令是用来注册用户控件的(是在.ascx文件里实现的),最后这个是用来注册编译进一个程序集 .dll 文件里的自定义控件的。注册完后,开发人员可以在页面的任何地方用设定好的 tagprefix (标识前缀)和标识符号名( tagname)来声明这些控件。

这行之有效,但管理起来会很痛苦,当你要在你的网站的许多页面上使用控件的话,尤其是,假如你移动了.ascx 文件,需要更新所有的注册声明的话。

解决方案:

ASP.NET 2.0 使得控件声明极其干净而且管理起来极其容易。不用在你的页面上重复这些声明,只要在你的应用的web.config 文件的新的 pages->controls 部分声明一次即可:

 

<?xml version="1.0"?>

<configuration>

  <system.web>
    
    <pages>
      <controls>
        <add tagPrefix="scottgu" src="~/Controls/Header.ascx" tagName="header"/>
        <add tagPrefix="scottgu" src="~/Controls/Footer.ascx" tagName="footer"/>
        <add tagPrefix="ControlVendor" assembly="ControlVendorAssembly"/>
      </controls>
    </pages>

  </system.web>

</configuration>
你可以用这种方式同时声明用户控件和编译好的自定义控件。当你使用这个技巧时,Visual Studio是完全支持这两者的,而且 VS 2005 Web Site 项目 和 VS 2005 Web Application 项目也都支持这两者。Visual Studio会在设计器里以所见即所得(WYSIWYG)模式显示这些控件,也会在后台编码文件里提示控件字段的声明。

需要注意的是,上面用户控件中“~”句法的使用。对那些不熟悉这个符号的人,ASP.NET中“~”符号意思是“从应用的根路径来定位”,它提供了一个很好的方法来避免在你的编码里到处使用“..\”。在web.config文件里声明用户控件时,你总是应该使用它,因为页面也许会使用在不同子目录里的控件,所以你应该总是始终如一地从应用的根路径开始定位这些控件。

一旦你在web.config 文件中声明好这些控件后,你就可以在你网站上的任何一个页面,母板页或者用户控件中使用它们了,象这样(不再需要注册指令):

 

<html>
<body>
    <form id="form1" runat="server">
        <scottgu:header ID="MyHeader" runat="server" />
    </form>
</body>
</html>
︿ 0
如果是我 我根本不会用什么数据库. 或者我的数据库也只有一个字段...

然后我这个表单 也要用ueditor +自己开发的按钮插件 来生成表单控件插入到html中..

表单设计完成之后 我会把整体的"html"当作一个字段来保存.... 比如

id  name              html
1   工资申请单     <div.......<input .....<.......

然后别人在使用的时候 我把这些html输出到页面上 这不就是一个表单了吗?

然后保存就更简单  我把整体的html都保存起来 . 这个时候 input上面是有value标签的... 所以值也保存起来了..

其他人在"审核" 或者"阅读"的时候 我在把这些html显示到页面.. 岂不是很简单??