WebFormsJS is the front-end part of the WebForms Core technology that communicates with the WebForms class on the back-end.
WebFormsJS is a JavaScript library that provides the infrastructure for interacting with web controls in the CodeBehind framework; this allows developers to easily manage HTML tags on the server-side.
WebForms Core is a new architecture similar to Microsoft's former Web-Forms, but has none of its disadvantages. The performance of WebForms Core is much more than the previous Web-Forms, so that it manages all HTML tags.
Using WebForms Core allows the developers to focus on the server response and therefore there is no need to develop the front side and the developers set the controls on the server-side. WebForms Core can also be used outside of the CodeBehind framework. In the rest of this article, we teach how to set the server response to interact with WebFormsJS.
The bandwidth consumption when using WebForms Core is very low. WebForms Core is like a gasoline car that absorbs carbon pollution as much as it pollutes the air.
Advantages:
- WebForms Core provides features like postback, progress bar and script extraction.
- WebForms Core is an advanced system that can be run with simple HTML pages without View or server script pages.
- WebFormsJS automatically sends form data through Ajax. WebFormsJS serializes form data as a string or a FormData object, depending on whether the form is multipart or not.
- Using WebForms Core technology reduces the complexity of web development.
To use WebForms Core technology, it is enough to add the WebFormsJS library in the head section of HTML and get the WebForms class associated with the server programming language from the WebForms class repository.
Note: In WebForms Core technology, the WebFormsJS library automatically communicates with the WebForms class on the server; therefore, you do not need to read the description of this repository. To use this technology, it is enough to become familiar with the classes and methods of the WebForms class on the server.
At the beginning of the web-forms.js file, there are WebFormsJS customization options. The following codes show the options of this file:
var PostBackOptions = new Object();
PostBackOptions.UseProgressBar = true;
PostBackOptions.UseConnectionErrorMessage = true;
PostBackOptions.ConnectionErrorMessage = "Connection Error";
PostBackOptions.AutoSetSubmitOnClick = true;
PostBackOptions.SendDataOnlyByPostMethod = false;
PostBackOptions.WebFormsTagsBackgroundColor = "#eee";
PostBackOptions.SetResponseInsideDivTag = true;
PostBackOptions.ProgressBarStyle = "width:100%;min-width:300px;max-width:600px;background-color:#eee;margin:2px 0px";
PostBackOptions.ProgressBarPercentLoadedStyle = "position:absolute;padding:0px 4px;line-height:22px";
PostBackOptions.ProgressBarValueStyle = "height:20px;background-color:#4D93DD;width:0%";
PostBackOptions.AddLogForWebSockets = true;WebFormsJS options:
- UseProgressBar: If there is a file input in the form, the progress bar will show the amount of data sent on the screen.
- UseConnectionErrorMessage: Enabling this option causes the error text to be displayed.
- ConnectionErrorMessage: The text to display when an error occurs.
- AutoSetSubmitOnClick: Enabling this option makes submit type inputs automatically send data through WebFormsJS.
- SendDataOnlyByPostMethod: Enabling this option causes the data to be sent with the Post method; Therefore, the form method is ignored.
- WebFormsTagsBackgroundColor: Before rendering the web-forms tags, it gives a default color to their background to improve the user experience.
- SetResponseInsideDivTag: Enabling this option determines whether the server response will be placed inside the div tag or not.
- ProgressBarStyle: Styles for progress bar
- ProgressBarPercentLoadedStyle: Styles for percentage and text size for progress bar
- ProgressBarValueStyle: Styles for uploading animation for progress bar
- AddLogForWebSockets: Enabling this option will log connections, disconnections, and data sent between the server and client in WebSocket protocol.
Action Controls are WebFormsJS received codes that are received in INI format. WebFormsJS automatically detects whether the server response has Action Controls or not. If the server's response is based on the structure of an INI file that starts with [web-forms], it will process the Action Controls, otherwise it will replace the server's response in the form of Ajax on the page.
Example of received Action Controls:
[web-forms]
as<body>=background-color:green
saCheckBoxInput=onchange|MyNewFunc()
deMyTagId=1
ta<i>2=right
aoSelectInput=OptionValue|Option Text|1
al(InputName)=My Input Title- Line 1: as<body>=background-color:greenHere, the first two characters areas, which means adding a style, and then it is specified that it will be applied to thebodytag, and after the equal character (=), the style attribute is specified.
- Line 2: saCheckBoxInput=onchange|MyNewFunc()Here, the first two characters aresa, which means adding an attribute, and then it is specified that it will be applied to a tag with the idCheckBoxInput, and after the equal character (=), the name and value of the attribute is specified, which is specified by the character (|) are separated.
- Line 3: deMyTagId=1Here, the first two characters arede, which means to delete the tag, and then it is determined that it will be applied to a tag with the idMyTagId, and after the equal character (=) there is a value of1, which means to apply deletion.
- Line 4: ta<i>2=rightHere, the first two characters areta, which means text align, and then it is determined that it will be applied to a third tag namedli, and after the equal character (=) there is a value of right which means right to left.
- Line 5: aoSelectInput=OptionValue|Option Text|1Here, the first two characters areao, which means adding the option tag, and then it is specified that it will be applied to a tag with the id nameSelectInput, and after the equal character (=), the option value is placed, and after the character (|) option text is placed and at the end after the (|) character is the number1, which means that the option is active (checked).
- Line 6: al(InputName)=My Input TitleHere, the first two characters areal, which means adding a title, and then it is specified that it will be applied to a tag namedInputName, and after the equal character (=), the title text is specified.
Action Controls are received in the form of an INI file format. In the first line of the response there is the word [web-forms] and each of the following lines is an action control.
The first two characters determine the action code. For example, things like adding styles and removing tags can be obtained from action codes. Usually the first two letters stand for actions and indicate that an action must be performed.
After the first two letters, there are 6 status types that specify the tag. Then the equal character is placed and after that the values are placed.
Below is the list of all action codes:
The following items are added to the available amount:
- ai: Add Id - Value: Id
- an: Add Name - Value: Name
- av: Add Value - Value: Value
- ac: Add Class - Value: Class
- as: Add Style - Value: Style
- ao: Add Option Tag - Value: Value|Text|1 or 0
- ak: Add CheckBox Tag - Value: Value|Text|1 or 0
- al: Add Title - Value: Title
- at: Add Text - Value: Text(string value$[ln];it replaces by\ncharacter)
- pt: Add Text To Up - Value: Text(string value$[ln];it replaces by\ncharacter)
- aa: Add Attribute - Value: Attribute|{Splitter}|{Value}
- nt: Add Tag - Value: TagName|Id
- ut: Add Tag To Up - Value: TagName|Id
- bt: Add Tag Before This Tag - Value: TagName|{Id}
- ft: Add Tag After This Tag - Value: TagName|{Id}
- ah: Add Hidden Tag - Value: Value|{Id}
The following replaces the existing values:
- si: Set Id - Value: Id
- sn: Set Name - Value: Name
- sv: Set Value - Value: Value
- sc: Set Class - Value: Class
- ss: Set Style - Value: Style
- so: Set Option Tag - Value: Value|Text|1 or 0
- sk: Set Checked - Value: For input with checked type 1 or 0- For any tagsValue|Text|1 or 0
- sl: Set Title - Value: Title
- st: Set Text - Value: Text(string value$[ln];it replaces by\ncharacter)
- sa: Set Attribute - Value: Attribute|{Value}
- sw: Set Width - Value: Width
- sh: Set Height - Value: Height
- bc: Set Background Color - Value: Color
- tc: Set Text Color - Value: Color
- fn: Set Font Name - Value: Name
- fs: Set Font Size - Value: Size
- fb: Set Font Bold - Value: 1 or 0
- vi: Set Visible - Value: 1 or 0
- ta: Set Text Align - Value: Align
- sr: Set Read Only - Value: 1 or 0
- sf: Set Focus - Value: 1 or 0
- sd: Set Disabled - Value: 1 or 0
- mn: Set Min Length - Value: Length
- mx: Set Max Length - Value: Length
- ts: Set Selected Value - Value: Value
- ti: Set Selected Index - Value: Index
- ks: Set Checked Value - Value: Value|1 or 0
- ki: Set Checked Index - Value: Index|1 or 0
- cu: Change Browser URL - Value: URL
The following items are added only if there are no pre-existing values:
- ii: Insert Id - Value: Id
- in: Insert Name - Value: Name
- iv: Insert Value - Value: Value
- ic: Insert Class - Value: Class
- is: Insert Style - Value: Style
- io: Insert Option Tag - Value: Value|Text|1 or 0
- ik: Insert CheckBox Tag - Value: Value|Text|1 or 0
- il: Insert Title - Value: Title
- it: Insert Text - Value: Text(string value$[ln];it replaces by\ncharacter)
- ia: Insert Attribute - Value: Attribute|{Splitter}|{Value}
The following will remove the current values:
- di: Delete Id - Value: 1
- dn: Delete Name - Value: 1
- dv: Delete Value - Value: 1
- dc: Delete Class - Value: Class
- ds: Delete Style - Value: Style(only the style name is entered without a value)
- do: Delete Option Tag - Value: Value or * (all tag)
- dk: Delete CheckBox Tag - Value: Value or * (all tag)
- dl: Delete Title - Value: 1
- dt: Delete Text - Value: 1
- da: Delete Attribute - Value: Attribute
- de: Delete Tag - Value: 1
- dp: Delete Parent Tag - Value: 1
The following increment the current numeric values:
- +n: Increase Minimum Length - Value: Number
- +x: Increase Maximum Length - Value: Number
- +f: Increase Font Size - Value: Number
- +w: Increase Width - Value: Number
- +h: Increase Height - Value: Number
- +v: Increase Value - Value: Number
The following decrease the current numerical values:
- -n: Descrease Minimum Length - Value: Number
- -x: Descrease Maximum Length - Value: Number
- -f: Descrease Font Size - Value: Number
- -w: Descrease Width - Value: Number
- -h: Descrease Height - Value: Number
- -v: Descrease Value - Value: Number
The following add event types to HTML tags:
- Ep: Set Post Event - Value: Html Event|* (for add response) or Output Place
- EP: Set Post Event Listener - Value: Html Event Listener|* (for add response) or Output Place
- Eg: Set Get Event - Value: Html Event|# (for current path) or Path|{Output Place}
- Eg: Set Get Event In Form - Value: Html Event|{Output Place}
- EG: Set Get Event Listener - Value: Html Event Listener|# (for current path) or Path|{Output Place}
- EG: Set Get Event In Form Listener - Value: Html Event Listener|{Output Place}
- Et: Set Tag Event - Value: Html Event|{Output Place}
- ET: Set Tag Event Listener - Value: Html Event Listener|{Output Place}
- Ew: Set WebSocket Event - Value: Html Event|Path
- EW: Set WebSocket Event Listener - Value: Html Event Listener|Path
- Rp: Remove Post Event - Value: Html Event
- RP: Remove Post Event Listener - Value: Html Event Listener
- Rg: Remove Get Event - Value: Html Event
- RG: Remove Get Event Listener - Value: Html Event Listener
- Rt: Remove Tag Event - Value: Html Event
- RT: Remove Tag Event Listener - Value: Html Event Listener
- Rt: Remove WebSocket Event - Value: Html Event
- RT: Remove WebSocket Event Listener - Value: Html Event Listener
The following items are temporarily stored in session storag.
- @gi: Save Id - Value: Key
- @gn: Save Name - Value: Key
- @gv: Save Value - Value: Key
- @ge: Save Value Length - Value: Key
- @gc: Save Class - Value: Key
- @gs: Save Style - Value: Key
- @gl: Save Title - Value: Key
- @gt: Save Text - Value: Key
- @go: Save Outer Text - Value: Key
- @gg: Save Text Length - Value: Key
- @ga: Save Attribute - Value: Key|Attribute
- @gw: Save Width - Value: Key
- @gh: Save Height - Value: Key
- @gr: Save Read Only - Value: Key
- @gx: Save Selected Index - Value: Key
- @ta: Save Text Align - Value: Key
- @nl: Save Child Nodes Length - Value: Key
- @vi: Save Visible - Value: Key
- @gu: Save Url - Value: Key|Url
- @gI: Save Index - Value: Key
The following items are permanently stored in local storag.
- @ci: Cache Id - Value: Key
- @cn: Cache Name - Value: Key
- @cv: Cache Value - Value: Key
- @ce: Cache Value Length - Value: Key
- @cc: Cache Class - Value: Key
- @cs: Cache Style - Value: Key
- @cl: Cache Title - Value: Key
- @ct: Cache Text - Value: Key
- @co: Cache Outer Text - Value: Key
- @cg: Cache Text Length - Value: Key
- @ca: Cache Attribute - Value: Key|Attribute
- @cw: Cache Width - Value: Key
- @ch: Cache Height - Value: Key
- @cr: Cache Read Only - Value: Key
- @cx: Cache Selected Index - Value: Key
- @Ta: Cache Text Align - Value: Key
- @Nl: Cache Child Nodes Length - Value: Key
- @Vi: Cache Visible - Value: Key
- @cu: Cache Url - Value: Key|Url
- @cI: Cache Index - Value: Key
The following values are built-in functions that are placed after the equals character (=):
- @_: Execute Script - Value: Script code
- @mr: Random Number - Value Max number|Min number
- @dy: Year
- @dm: Month
- @dd: Day
- @dh: Hours
- @di: Minutes
- @ds: Seconds
- @dl: Milliseconds
- @co: Get Cookie - Value Key
- @cs: Sessioc Cache - Value Key|Replacement value
- @cl: Sessioc Cache Then Delete It - Value Key|Replacement value
- @cd: Cache - Value Key|Replacement value
- @ct: Cache Then Delete It - Value Key|Replacement value
- @_: Script - Value Script text
- @lu: Script - Value Url
- @lL: Session Cache Line - Value Key[{Line} (without this, it reads the first line then deletes it)
- @lI: Session Cache INI - Value Key[{INIKey}
- @dL: Cache Line - Value Key[{Line} (without this, it reads the first line then deletes it)
- @dI: Cache INI - Value Key[{INIKey}
- @ek: Event Key
- @ew: Event Which
- @ex: Event Client X
- @ey: Event Client Y
- @eX: Event Page X
- @eY: Event Page Y
- @Ex: Event Offset X
- @Ey: Event Offset Y
Note: Action controls are executed sequentially; if an action control decides to change an
idattribute from a tag, subsequent action controls cannot perform actions with the previousidattribute.
Note: You can also use negative numbers in all indexes. This makes access to tags or values to be read from the end.
Example:
de<li>-1=1
In the example above, the last li tag is removed.
- _: Execute Script - Value: Script code
- cd: Cache - Value: Cache duration(Specifies the cache duration in seconds. Inserting the (*) character instead of a numeric value creates a permanent cache.)
- cs: Session Cache - Value: Cache duration(Specifies the cache duration in seconds. This cache only works while the browser is active.)
- rd: Remove Cache - Value: Cache key(Deletes the cache based on the cache key. Inserting the (*) character instead of a cache name will delete all caches.)
- rs: Remove Session Cache - Value: Cache key(Deletes the cache session based on the cache key. Inserting the (*) character instead of a cache name will delete all caches.)
Pre Runners are added before Action Control values.
Each Pre Runner usually consists of one character, followed by the values of the Pre Runner, and then ends with the closing parenthesis ()) character.
- :: Delay - Value: Second
- (: Period - Value: Second
Example:
(4)+w<b>1=10px
The above example means that every 4 seconds, the width of the second b tag is added by 10 pixels.
Pre Runners are placed in the queue and can be called one after the other.
Example:
:10)(4)+w<b>1=10px
The above example is the same as the previous example, except that it is executed after 10 seconds.
The following items are related to multiple answers:
- #: Start Index - Value: {Name}
- &: Go To - Value: Number (Line) or #Index|Repeat
The following items enable and disable some features:
- ew: Enable WebSocket - Value: @ (for enable once) or 1 or 0
The following items determine the use of some features:
- uw: Use WebSocket - Value: path
After the first two characters, there are 6 status types that define the tag:
- Based on id: Based on the name of theid, it recognizes the tag and the character (=) is placed immediately after it.
- By name: Identifies the tag based on thenameattribute. It is placed in open and closed parentheses ((Name)), and if a number is placed after it, it specifies the index, and then the (=) character is placed after it.
- Based on the tag name: Based on thetag name, it recognizes the tag. It is placed inside the smaller and larger signs (<tag name>)), and if a number is placed after it, it specifies the index, and then the (=) character is placed after it.
- Based on class name: Identifies the tag based on theclass name. It is placed in open and closed brackets ({class name}), and if a number is placed after it, it specifies the index, and then the character (=) is placed after it.
- Based on query: Identifies the tag based on thequery. The query string is placed after the (*) character , and then the character (=) is placed after it. If there are equal characters (=) in the query value, they should be replaced by$[eq];string.
- Based on query all: It applies to multiple tags and identifies tags based on "query". The query string is placed after the ([) character , and then the character (=) is placed after it. If there are equal characters (=) in the query value, they should be replaced by$[eq];string.
Note: By default, the es of the
name,class name, andtag nameare set to0.
Example: Action control with the value de<li>=1 is not different from the value de<li>0=1.
You can also specify the desired tag nested (query all is not supported in this case).
Example:
at>{my-class}1|<u>|<li>2=My text string
In the example above, the My text string is placed inside the third li tag which is inside the first ul tag, and the ul tag itself is a tag inside the tag whose class is equal to the value of my-class.
You can also specify parent tags based on a tag.
Example:
/<p>4
In the above example, the parent of the fifth p tag is selected. You can select higher parents by adding multiple slash characters /.
WebFormsJS allows you to create web-forms tags on pages. The web-forms tags must have one of the src and ac attributes or both of them.
The ac attribute has the Action Controls value. Action Controls in this tag are separated by $[sln]; string.
Example:
<web-forms ac="nt<body>=div|MyDivTag$[sln];shMyDivTag=500px$[sln];swMyDivTag=500px$[sln];2)bci24=violet"></web-forms>
Note: The value of the ac attribute must not contain the double-quote character ("), and the string $[dq]; must be used instead.
The src attribute takes the value of a URL path. WebFormsJS calls the URL contained in the src attribute and puts the URL response inside the same web-forms tag. You can also set the width and height attributes in the web-forms tag.
Example:
<web-forms src="/page/header.aspx"></web-forms>
WebFormsJS has a different approach to responding to the first page request in the browser and AJAX requests when the page is already loaded and the user makes a request.
In the first case, if an action is added for the controls, a tag named web-forms is added at the bottom of the page, and the actions are placed in the ac attribute of the web-forms tag.
Example:
<!DOCTYPE html>
<html>
<head>
...
</head>
<body>
...
	<input name="TextBox" id="TextBox" type="text" />
...
</body>
</html><web-forms ac="bc<body>=green"></web-forms>In the second case, after the user's request, if the current View is changed, the server must place the Set Text code for the main tag (usually body) at the beginning of the action code.
Example:
[web-forms]
st<body>=...$[ln];	<input name="TextBox" id="TextBox" type="text" />$[ln];...
bc<body>=greenNote: When a request is made with WebFormJS, a header with the name
Post-Backand the valuetrueis also sent to the server. Therefore, it is easy to determine the response approach on the server.
Multiple-Responses is a useful feature in WebFormsJS that allows us to send multiple related responses in a single server response. The multi-response feature is a functionality similar to a JavaScript file that contains multiple offline functions (things that are not requested from the server).
In multiple-responses, action controls are separated by a # character. To execute the response, we need to add the # character and the  to the end of the path.
Example:
Response
[web-forms]
bcTextBox1=green
vi*h2:nth-of-type(2)=0
#
ta{my-textbox}1=right
Eg{my-list}=onmouseenter|#
fs<li>1=24px
#
ac(gender)2=my-css-class
sv(email)=myemail@gmail.com
#=MyIndex
as[h2:nth-of-type(2)=margin:10px 20px
bc<form>|<p>=violet
tc<form>|<p>=yellow
Path and result
Requesting /my-view.aspx or /my-view.aspx#0
The following action controls are performed:
bcTextBox1=green
vi*h2:nth-of-type(2)=0
Requesting /my-view.aspx#1
The following action controls are performed:
ta{my-textbox}1=right
Eg{my-list}=onmouseenter|#
fs<li>1=24px
Requesting /my-view.aspx#2
The following action controls are performed:
ac(gender)2=my-css-class
sv(email)=myemail@gmail.com
Requesting /my-view.aspx#MyIndex or /my-view.aspx#3
The following action controls are performed:
as[h2:nth-of-type(2)=margin:10px 20px
bc<form>|<p>=violet
tc<form>|<p>=yellow
Note: Multiple-Responses are mostly used for offline cases and it is recommended to enable HTML headers for long-term client-side caching for multiple responses.
WebForms Core technology also supports the WebSocket protocol.
Sending data in WebSocket mode is also possible with form submission. In order to send data under the WebSocket protocol, you must either enable the use of WebForms class methods on the server. Of course, you can also send under the WebSocket protocol by adding the usewebsocket attribute to the form tag.
Example:
<form action="/mypage" method="post" usewebsocket>
	Text
	<br>
	<textarea name="Textarea1"></textarea><br><br>
	<input type="submit" name="Button1" value="Send">
</form>PostBack and GetBack are two methods in WebFormsJS.
PostBack requests the URL string in the condition that it also transfers the input data to the server. The PostBack method should only be used inside a form tag. The PostBack method is automatically activated on submit type inputs.
GetBack only requests the URL string regardless of the input data. The URL string can also contain the query string. The GetBack method can be used without the form tag on the page.
There are three overloads for the GetBack method:
- GetBack(event): Requests the current URL path executed in the browser.
- GetBack(event, this): Should be used only in situations where the form tag must be present on the page. If executed inside a form, the action path requests the form, otherwise it requests the path of the first form on the page.
- GetBack(event, "YourURL"): Requests the URL path entered as an argument.
Calling WebFormJS in HTML pages causes submit buttons to automatically get the onclick attribute with PostBack(event) value.
<input name="btn_Button" type="submit" value="Click to send data" onclick="PostBack(event)"/>
If you call the PostBack method as below, the contents of the page will remain and the values will be added to the beginning of the inner content of the body tag.
PostBack(event, true)
You can specify where to add content instead of true.
Example1:
PostBack(event, "<div>2")
The above method places the data received from the server inside the third div tag.
Example2:
PostBack(event, "MyTagId")
The above method puts the data received from the server inside a tag or MyTagId id.
Note: Examples 1 and 2 for the
GetBackmethod also have the same function.
TagBack method renders the action control of a web-forms tag.
Example:
TagBack (event, "(my-class)-1")
The above method renders the action control of the last web-forms tag whose class name is my-class.
Example web-forms tag
<web-forms class="my-class" ac="bc<body>=red"></web-forms>
WebSocketBack method creates a WebSocket connection along the path of the passed argument.
Example:
WebSocketBack(event, "/YourURL")
The above method creates a WebSocket connection to the path "/YourURL".
PreventDefault method prevents default browser behavior associated with specific tag-driven events
Example:
PreventDefault(event)
<a href="https://example.com" id="myLink" onclick="PreventDefault(event)">Go to Example</a>
Normally, clicking the link would take you to example.com. PreventDefault method stops that action and does something else—like showing an alert.
StopPropagation prevents the event from occurring on its parent tags.
Example:
StopPropagation(event)
<div onclick="alert('DIV clicked!')">
  <button onclick="StopPropagation(event)">Click Me</button>
</div>In the above example, the alert is not displayed when the button is clicked.
