举报投诉联系我们 手机版 热门标签 编程学
您的位置:编程学 > js转换工具 JSF 自定义转换器示例

js转换工具 JSF 自定义转换器示例

2023-03-19 04:18 Java教程

js转换工具 JSF 自定义转换器示例

js转换工具

JavaScript转换工具是一种用于将JavaScript代码转换为可以在浏览器中运行的代码的工具。它可以帮助开发人员将复杂的JavaScript代码转换为浏览器可以理解的格式,从而使Web应用程序更加高效。

JavaScript转换工具有很多不同的形式,但它们都有一个共同的目标:将JavaScript代码转换为浏览器可以理解的格式。例如,一些工具可以将ES6语法转换为ES5语法,这样就可以在所有浏览器中运行。此外,它还可以将ES6模块化语法转换为CommonJS或AMD语法,使得Web应用程序能够在不同的浏览器上正常运行。

// ES6 代码 
import React from 'react'; 
export default class App extends React.Component { 
    render() { 
        return 
Hello World!
; } } // 转换后的 ES5 代码 var React = require('react'); module.exports = function App() { return React.createElement("div", null, "Hello World!"); };

JSF 自定义转换器示例

JSF教程 - JSF自定义转换器示例


我们可以在JSF中创建我们自己的自定义转换器。

以下列表是我们可以按照在JSF中创建自定义转换器的步骤。

  • 通过实现javax.faces.convert.Converter接口创建转换器类。
  • 实现上述接口的getAsObject()和getAsString()方法。
  • 使用注释@FacesConvertor为自定义转换器分配唯一的ID。

例子

以下代码来自URLConverter.java。

package cn..common;
import javax.faces.application.FacesMessage;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
import javax.faces.convert.ConverterException;
import javax.faces.convert.FacesConverter;

@FacesConverter("cn..common.URLConverter")
public class URLConverter implements Converter{
  @Override
  public Object getAsObject(FacesContext context, UIComponent component,
      String value) {
    
    String HTTP = "http://";
    StringBuilder url = new StringBuilder();

    if(!value.startsWith(HTTP, 0)){
      url.append(HTTP);
    }
    url.append(value);
    
    if(url.toString().length() > 10){
      FacesMessage msg = 
        new FacesMessage("URL Conversion error.", 
            "Invalid URL format.");
      msg.setSeverity(FacesMessage.SEVERITY_ERROR);
      throw new ConverterException(msg);
    }
    return url.toString();
  }

  @Override
  public String getAsString(FacesContext context, UIComponent component,
      Object value) {

    return value.toString();
    
  }
  
  
}

下面的代码来自UserBean.java。

package cn..common;


import java.io.Serializable;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
 
@ManagedBean(name="user")
@SessionScoped
public class UserBean implements Serializable{
  
  String bookmarkURL;

  public String getBookmarkURL() {
    return bookmarkURL;
  }

  public void setBookmarkURL(String bookmarkURL) {
    this.bookmarkURL = bookmarkURL;
  }

}

以下代码来自result.xhtml。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"   
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:c="http://java.sun.com/jsp/jstl/core"
      >
    <h:body>
      <h:panelGrid columns="2">
      
        Bookmark URL :  
        <h:outputText value="#{user.bookmarkURL}" />
        
      </h:panelGrid>
      
    </h:body>
</html>

以下代码来自demo.xhtml。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"   
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      >
    <h:body>
    <h:form>
      <h:panelGrid columns="3">
        Enter your bookmark URL :
        <h:inputText id="bookmarkURL" value="#{user.bookmarkURL}" 
          size="20" required="true" label="Bookmark URL">
          <f:converter converterId="cn..common.URLConverter" />
        </h:inputText>
        
        <h:message for="bookmarkURL" style="color:red" />
      
      </h:panelGrid>
      
      <h:commandButton value="Submit" action="result" />
      
    </h:form>
    
    </h:body>
</html>
下载 Custom-Converter.zip

运行

将生成的WAR文件从目标文件夹复制到Tomcat部署文件夹,并运行Tomcat-Install-folder/bin/startup.bat。

Tomcat完成启动后,在浏览器地址栏中键入以下URL。

http://localhost:8080/simple-webapp/demo.xhtml
阅读全文
以上是编程学为你收集整理的js转换工具 JSF 自定义转换器示例全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 编程学 bianchengxue.com 版权所有 联系我们
桂ICP备19012293号-7 返回底部